@cardano-sdk/projection-typeorm 0.2.0-nightly.3 → 0.2.0-nightly.5
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/README.md +10 -1
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts +6 -6
- package/dist/cjs/TypeormStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/cjs/TypeormStabilityWindowBuffer.js +42 -21
- package/dist/cjs/TypeormStabilityWindowBuffer.js.map +1 -1
- package/dist/cjs/createDataSource.d.ts +9 -4
- package/dist/cjs/createDataSource.d.ts.map +1 -1
- package/dist/cjs/createDataSource.js +49 -34
- package/dist/cjs/createDataSource.js.map +1 -1
- package/dist/cjs/entity/Asset.entity.d.ts +8 -0
- package/dist/cjs/entity/Asset.entity.d.ts.map +1 -0
- package/dist/cjs/entity/Asset.entity.js +40 -0
- package/dist/cjs/entity/Asset.entity.js.map +1 -0
- package/dist/cjs/entity/Block.entity.d.ts.map +1 -1
- package/dist/cjs/entity/Block.entity.js +3 -3
- package/dist/cjs/entity/Block.entity.js.map +1 -1
- package/dist/cjs/entity/BlockData.entity.js +1 -1
- package/dist/cjs/entity/BlockData.entity.js.map +1 -1
- package/dist/cjs/entity/Output.entity.d.ts +17 -0
- package/dist/cjs/entity/Output.entity.d.ts.map +1 -0
- package/dist/cjs/entity/Output.entity.js +72 -0
- package/dist/cjs/entity/Output.entity.js.map +1 -0
- package/dist/cjs/entity/PoolMetadata.entity.d.ts +15 -0
- package/dist/cjs/entity/PoolMetadata.entity.d.ts.map +1 -0
- package/dist/cjs/entity/PoolMetadata.entity.js +63 -0
- package/dist/cjs/entity/PoolMetadata.entity.js.map +1 -0
- package/dist/cjs/entity/Tokens.entity.d.ts +9 -0
- package/dist/cjs/entity/Tokens.entity.d.ts.map +1 -0
- package/dist/cjs/entity/Tokens.entity.js +41 -0
- package/dist/cjs/entity/Tokens.entity.js.map +1 -0
- package/dist/cjs/entity/index.d.ts +4 -0
- package/dist/cjs/entity/index.d.ts.map +1 -1
- package/dist/cjs/entity/index.js +4 -0
- package/dist/cjs/entity/index.js.map +1 -1
- package/dist/cjs/index.d.ts +6 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +9 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/{util.d.ts → isRecoverableTypeormError.d.ts} +1 -1
- package/dist/cjs/isRecoverableTypeormError.d.ts.map +1 -0
- package/dist/cjs/{util.js → isRecoverableTypeormError.js} +1 -1
- package/dist/cjs/isRecoverableTypeormError.js.map +1 -0
- package/dist/cjs/operators/index.d.ts +9 -0
- package/dist/cjs/operators/index.d.ts.map +1 -0
- package/dist/cjs/operators/index.js +25 -0
- package/dist/cjs/operators/index.js.map +1 -0
- package/dist/cjs/operators/storeAssets.d.ts +3 -0
- package/dist/cjs/operators/storeAssets.d.ts.map +1 -0
- package/dist/cjs/operators/storeAssets.js +27 -0
- package/dist/cjs/operators/storeAssets.js.map +1 -0
- package/dist/cjs/operators/storeBlock.d.ts +2 -0
- package/dist/cjs/operators/storeBlock.d.ts.map +1 -0
- package/dist/cjs/operators/storeBlock.js +23 -0
- package/dist/cjs/operators/storeBlock.js.map +1 -0
- package/dist/cjs/operators/storeStakeKeys.d.ts +3 -0
- package/dist/cjs/operators/storeStakeKeys.d.ts.map +1 -0
- package/dist/cjs/operators/storeStakeKeys.js +12 -0
- package/dist/cjs/operators/storeStakeKeys.js.map +1 -0
- package/dist/cjs/operators/storeStakePoolMetadataJob.d.ts +4 -0
- package/dist/cjs/operators/storeStakePoolMetadataJob.d.ts.map +1 -0
- package/dist/cjs/operators/storeStakePoolMetadataJob.js +22 -0
- package/dist/cjs/operators/storeStakePoolMetadataJob.js.map +1 -0
- package/dist/cjs/operators/storeStakePools.d.ts +4 -0
- package/dist/cjs/operators/storeStakePools.d.ts.map +1 -0
- package/dist/cjs/{sinks/stakePools.sink.js → operators/storeStakePools.js} +13 -13
- package/dist/cjs/operators/storeStakePools.js.map +1 -0
- package/dist/cjs/operators/storeUtxo.d.ts +3 -0
- package/dist/cjs/operators/storeUtxo.d.ts.map +1 -0
- package/dist/cjs/operators/storeUtxo.js +41 -0
- package/dist/cjs/operators/storeUtxo.js.map +1 -0
- package/dist/cjs/operators/util.d.ts +7 -0
- package/dist/cjs/operators/util.d.ts.map +1 -0
- package/dist/cjs/operators/util.js +12 -0
- package/dist/cjs/operators/util.js.map +1 -0
- package/dist/cjs/operators/withTypeormTransaction.d.ts +23 -0
- package/dist/cjs/operators/withTypeormTransaction.d.ts.map +1 -0
- package/dist/cjs/operators/withTypeormTransaction.js +49 -0
- package/dist/cjs/operators/withTypeormTransaction.js.map +1 -0
- package/dist/cjs/pgBoss.d.ts +26 -0
- package/dist/cjs/pgBoss.d.ts.map +1 -0
- package/dist/cjs/pgBoss.js +169 -0
- package/dist/cjs/pgBoss.js.map +1 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/TypeormStabilityWindowBuffer.d.ts +6 -6
- package/dist/esm/TypeormStabilityWindowBuffer.d.ts.map +1 -1
- package/dist/esm/TypeormStabilityWindowBuffer.js +42 -21
- package/dist/esm/TypeormStabilityWindowBuffer.js.map +1 -1
- package/dist/esm/createDataSource.d.ts +9 -4
- package/dist/esm/createDataSource.d.ts.map +1 -1
- package/dist/esm/createDataSource.js +47 -10
- package/dist/esm/createDataSource.js.map +1 -1
- package/dist/esm/entity/Asset.entity.d.ts +8 -0
- package/dist/esm/entity/Asset.entity.d.ts.map +1 -0
- package/dist/esm/entity/Asset.entity.js +37 -0
- package/dist/esm/entity/Asset.entity.js.map +1 -0
- package/dist/esm/entity/Block.entity.d.ts.map +1 -1
- package/dist/esm/entity/Block.entity.js +3 -3
- package/dist/esm/entity/Block.entity.js.map +1 -1
- package/dist/esm/entity/BlockData.entity.js +1 -1
- package/dist/esm/entity/BlockData.entity.js.map +1 -1
- package/dist/esm/entity/Output.entity.d.ts +17 -0
- package/dist/esm/entity/Output.entity.d.ts.map +1 -0
- package/dist/esm/entity/Output.entity.js +69 -0
- package/dist/esm/entity/Output.entity.js.map +1 -0
- package/dist/esm/entity/PoolMetadata.entity.d.ts +15 -0
- package/dist/esm/entity/PoolMetadata.entity.d.ts.map +1 -0
- package/dist/esm/entity/PoolMetadata.entity.js +60 -0
- package/dist/esm/entity/PoolMetadata.entity.js.map +1 -0
- package/dist/esm/entity/Tokens.entity.d.ts +9 -0
- package/dist/esm/entity/Tokens.entity.d.ts.map +1 -0
- package/dist/esm/entity/Tokens.entity.js +38 -0
- package/dist/esm/entity/Tokens.entity.js.map +1 -0
- package/dist/esm/entity/index.d.ts +4 -0
- package/dist/esm/entity/index.d.ts.map +1 -1
- package/dist/esm/entity/index.js +4 -0
- package/dist/esm/entity/index.js.map +1 -1
- package/dist/esm/index.d.ts +6 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +6 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/{util.d.ts → isRecoverableTypeormError.d.ts} +1 -1
- package/dist/esm/isRecoverableTypeormError.d.ts.map +1 -0
- package/dist/esm/{util.js → isRecoverableTypeormError.js} +1 -1
- package/dist/esm/isRecoverableTypeormError.js.map +1 -0
- package/dist/esm/operators/index.d.ts +9 -0
- package/dist/esm/operators/index.d.ts.map +1 -0
- package/dist/esm/operators/index.js +9 -0
- package/dist/esm/operators/index.js.map +1 -0
- package/dist/esm/operators/storeAssets.d.ts +3 -0
- package/dist/esm/operators/storeAssets.d.ts.map +1 -0
- package/dist/esm/operators/storeAssets.js +24 -0
- package/dist/esm/operators/storeAssets.js.map +1 -0
- package/dist/esm/operators/storeBlock.d.ts +2 -0
- package/dist/esm/operators/storeBlock.d.ts.map +1 -0
- package/dist/esm/operators/storeBlock.js +20 -0
- package/dist/esm/operators/storeBlock.js.map +1 -0
- package/dist/esm/operators/storeStakeKeys.d.ts +3 -0
- package/dist/esm/operators/storeStakeKeys.d.ts.map +1 -0
- package/dist/esm/operators/storeStakeKeys.js +9 -0
- package/dist/esm/operators/storeStakeKeys.js.map +1 -0
- package/dist/esm/operators/storeStakePoolMetadataJob.d.ts +4 -0
- package/dist/esm/operators/storeStakePoolMetadataJob.d.ts.map +1 -0
- package/dist/esm/operators/storeStakePoolMetadataJob.js +19 -0
- package/dist/esm/operators/storeStakePoolMetadataJob.js.map +1 -0
- package/dist/esm/operators/storeStakePools.d.ts +4 -0
- package/dist/esm/operators/storeStakePools.d.ts.map +1 -0
- package/dist/esm/{sinks/stakePools.sink.js → operators/storeStakePools.js} +13 -13
- package/dist/esm/operators/storeStakePools.js.map +1 -0
- package/dist/esm/operators/storeUtxo.d.ts +3 -0
- package/dist/esm/operators/storeUtxo.d.ts.map +1 -0
- package/dist/esm/operators/storeUtxo.js +38 -0
- package/dist/esm/operators/storeUtxo.js.map +1 -0
- package/dist/esm/operators/util.d.ts +7 -0
- package/dist/esm/operators/util.d.ts.map +1 -0
- package/dist/esm/operators/util.js +7 -0
- package/dist/esm/operators/util.js.map +1 -0
- package/dist/esm/operators/withTypeormTransaction.d.ts +23 -0
- package/dist/esm/operators/withTypeormTransaction.d.ts.map +1 -0
- package/dist/esm/operators/withTypeormTransaction.js +41 -0
- package/dist/esm/operators/withTypeormTransaction.js.map +1 -0
- package/dist/esm/pgBoss.d.ts +26 -0
- package/dist/esm/pgBoss.d.ts.map +1 -0
- package/dist/esm/pgBoss.js +161 -0
- package/dist/esm/pgBoss.js.map +1 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +12 -11
- package/dist/cjs/createSinks.d.ts +0 -19
- package/dist/cjs/createSinks.d.ts.map +0 -1
- package/dist/cjs/createSinks.js +0 -101
- package/dist/cjs/createSinks.js.map +0 -1
- package/dist/cjs/sinks/index.d.ts +0 -3
- package/dist/cjs/sinks/index.d.ts.map +0 -1
- package/dist/cjs/sinks/index.js +0 -8
- package/dist/cjs/sinks/index.js.map +0 -1
- package/dist/cjs/sinks/stakeKeys.sink.d.ts +0 -4
- package/dist/cjs/sinks/stakeKeys.sink.d.ts.map +0 -1
- package/dist/cjs/sinks/stakeKeys.sink.js +0 -15
- package/dist/cjs/sinks/stakeKeys.sink.js.map +0 -1
- package/dist/cjs/sinks/stakePools.sink.d.ts +0 -4
- package/dist/cjs/sinks/stakePools.sink.d.ts.map +0 -1
- package/dist/cjs/sinks/stakePools.sink.js.map +0 -1
- package/dist/cjs/sinks/util.d.ts +0 -5
- package/dist/cjs/sinks/util.d.ts.map +0 -1
- package/dist/cjs/sinks/util.js +0 -8
- package/dist/cjs/sinks/util.js.map +0 -1
- package/dist/cjs/types.d.ts +0 -16
- package/dist/cjs/types.d.ts.map +0 -1
- package/dist/cjs/types.js +0 -3
- package/dist/cjs/types.js.map +0 -1
- package/dist/cjs/util.d.ts.map +0 -1
- package/dist/cjs/util.js.map +0 -1
- package/dist/esm/createSinks.d.ts +0 -19
- package/dist/esm/createSinks.d.ts.map +0 -1
- package/dist/esm/createSinks.js +0 -70
- package/dist/esm/createSinks.js.map +0 -1
- package/dist/esm/sinks/index.d.ts +0 -3
- package/dist/esm/sinks/index.d.ts.map +0 -1
- package/dist/esm/sinks/index.js +0 -3
- package/dist/esm/sinks/index.js.map +0 -1
- package/dist/esm/sinks/stakeKeys.sink.d.ts +0 -4
- package/dist/esm/sinks/stakeKeys.sink.d.ts.map +0 -1
- package/dist/esm/sinks/stakeKeys.sink.js +0 -12
- package/dist/esm/sinks/stakeKeys.sink.js.map +0 -1
- package/dist/esm/sinks/stakePools.sink.d.ts +0 -4
- package/dist/esm/sinks/stakePools.sink.d.ts.map +0 -1
- package/dist/esm/sinks/stakePools.sink.js.map +0 -1
- package/dist/esm/sinks/util.d.ts +0 -5
- package/dist/esm/sinks/util.d.ts.map +0 -1
- package/dist/esm/sinks/util.js +0 -4
- package/dist/esm/sinks/util.js.map +0 -1
- package/dist/esm/types.d.ts +0 -16
- package/dist/esm/types.d.ts.map +0 -1
- package/dist/esm/types.js +0 -2
- package/dist/esm/types.js.map +0 -1
- package/dist/esm/util.d.ts.map +0 -1
- package/dist/esm/util.js.map +0 -1
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { NEVER, Subject, concat, defer, from, map, mergeMap, switchMap, tap } from 'rxjs';
|
|
2
|
+
import { createPgBossExtension } from '../pgBoss';
|
|
3
|
+
import { withEventContext, withStaticContext } from '@cardano-sdk/projection';
|
|
4
|
+
import { finalizeWithLatest } from '@cardano-sdk/util-rxjs';
|
|
5
|
+
import omit from 'lodash/omit';
|
|
6
|
+
const WithTypeormTransactionProps = ['queryRunner', 'transactionCommitted$', 'pgBoss'];
|
|
7
|
+
export function withTypeormTransaction({ dataSource$, logger }, extensions) {
|
|
8
|
+
return (evt$) => evt$.pipe(withStaticContext(defer(() => dataSource$.pipe(switchMap((dataSource) => concat(from((async () => {
|
|
9
|
+
const queryRunner = dataSource.createQueryRunner('master');
|
|
10
|
+
await queryRunner.connect();
|
|
11
|
+
if (extensions?.pgBoss) {
|
|
12
|
+
const pgBoss = createPgBossExtension(queryRunner);
|
|
13
|
+
return { pgBoss, queryRunner };
|
|
14
|
+
}
|
|
15
|
+
return { queryRunner };
|
|
16
|
+
})()), NEVER).pipe(finalizeWithLatest(async (evt) => {
|
|
17
|
+
if (!evt)
|
|
18
|
+
return;
|
|
19
|
+
if (evt.queryRunner.isTransactionActive) {
|
|
20
|
+
try {
|
|
21
|
+
await evt.queryRunner.rollbackTransaction();
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
logger.error('Failed to rollback transaction', error);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (!evt.queryRunner.isReleased) {
|
|
28
|
+
try {
|
|
29
|
+
await evt.queryRunner.release();
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
logger.error('Failed to "release" query runner', error);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
})))))), withEventContext(({ queryRunner }) => from(queryRunner.startTransaction('SERIALIZABLE').then(() => ({ transactionCommitted$: new Subject() })))));
|
|
36
|
+
}
|
|
37
|
+
export const typeormTransactionCommit = () => (evt$) => evt$.pipe(mergeMap((evt) => from(evt.queryRunner.commitTransaction()).pipe(tap(() => evt.transactionCommitted$.next()), map(() => {
|
|
38
|
+
const result = omit(evt, WithTypeormTransactionProps);
|
|
39
|
+
return result;
|
|
40
|
+
}))));
|
|
41
|
+
//# sourceMappingURL=withTypeormTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withTypeormTransaction.js","sourceRoot":"","sources":["../../../src/operators/withTypeormTransaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
3
|
+
import { QueryRunner } from 'typeorm';
|
|
4
|
+
import EventEmitter from 'events';
|
|
5
|
+
export declare const STAKE_POOL_METADATA_QUEUE = "STAKE_POOL_METADATA";
|
|
6
|
+
export interface PgBossExtension {
|
|
7
|
+
send: <T extends object>(taskName: string, data: T, options: {
|
|
8
|
+
slot: Cardano.Slot;
|
|
9
|
+
}) => Promise<string | null>;
|
|
10
|
+
}
|
|
11
|
+
export interface StakePoolMetadataJob {
|
|
12
|
+
poolRegistrationId: string;
|
|
13
|
+
poolId: Cardano.PoolId;
|
|
14
|
+
metadataJson: NonNullable<Cardano.StakePool['metadataJson']>;
|
|
15
|
+
}
|
|
16
|
+
export declare class BossDb extends EventEmitter {
|
|
17
|
+
#private;
|
|
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;
|
|
26
|
+
//# sourceMappingURL=pgBoss.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
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,WAAW,EAAE,MAAM,SAAS,CAAC;AAGtC,OAAO,YAAY,MAAM,QAAQ,CAAC;AAGlC,eAAO,MAAM,yBAAyB,wBAAwB,CAAC;AAE/D,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,CAAC,CAAC,SAAS,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,OAAO,EAAE;QAAE,IAAI,EAAE,OAAO,CAAC,IAAI,CAAA;KAAE,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAChH;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;AAED,qBAAa,MAAO,SAAQ,YAAY;;IACtC,MAAM,UAAQ;gBAGF,WAAW,EAAE,WAAW;IAK9B,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE;;;;CAKjD;AA6JD,eAAO,MAAM,qBAAqB,gBAAiB,WAAW,KAAG,eAUhE,CAAC"}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
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;
|
|
13
|
+
import { v4 } from 'uuid';
|
|
14
|
+
import Attorney from 'pg-boss/src/attorney';
|
|
15
|
+
import EventEmitter from 'events';
|
|
16
|
+
import PgBoss from 'pg-boss';
|
|
17
|
+
export const STAKE_POOL_METADATA_QUEUE = 'STAKE_POOL_METADATA';
|
|
18
|
+
export class BossDb extends EventEmitter {
|
|
19
|
+
constructor(queryRunner) {
|
|
20
|
+
super();
|
|
21
|
+
this.opened = true;
|
|
22
|
+
_BossDb_queryRunner.set(this, void 0);
|
|
23
|
+
__classPrivateFieldSet(this, _BossDb_queryRunner, queryRunner, "f");
|
|
24
|
+
}
|
|
25
|
+
async executeSql(text, values) {
|
|
26
|
+
return __classPrivateFieldGet(this, _BossDb_queryRunner, "f")
|
|
27
|
+
.query(text, values, true)
|
|
28
|
+
.then(({ records, affected }) => ({ rowCount: affected || 0, rows: records }));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
_BossDb_queryRunner = new WeakMap();
|
|
32
|
+
async function createJob(name, data, options, singletonOffset = 0) {
|
|
33
|
+
const { db: wrapper, expireIn, priority, startAfter, keepUntil, singletonKey = null, singletonSeconds, retryBackoff, retryLimit, retryDelay, onComplete, slot } = options;
|
|
34
|
+
const id = v4();
|
|
35
|
+
const values = [
|
|
36
|
+
id,
|
|
37
|
+
name,
|
|
38
|
+
priority,
|
|
39
|
+
retryLimit,
|
|
40
|
+
startAfter,
|
|
41
|
+
expireIn,
|
|
42
|
+
data,
|
|
43
|
+
singletonKey,
|
|
44
|
+
singletonSeconds,
|
|
45
|
+
singletonOffset,
|
|
46
|
+
retryDelay,
|
|
47
|
+
retryBackoff,
|
|
48
|
+
keepUntil,
|
|
49
|
+
onComplete,
|
|
50
|
+
slot
|
|
51
|
+
];
|
|
52
|
+
const db = wrapper || this.manager.db;
|
|
53
|
+
const result = await db.executeSql(this.insertJobCommand, values);
|
|
54
|
+
if (result && result.rowCount === 1) {
|
|
55
|
+
return result.rows[0].id;
|
|
56
|
+
}
|
|
57
|
+
if (!options.singletonNextSlot) {
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
options.startAfter = this.manager.getDebounceStartAfter(singletonSeconds, this.manager.timekeeper.clockSkew);
|
|
61
|
+
options.singletonNextSlot = false;
|
|
62
|
+
singletonOffset = singletonSeconds;
|
|
63
|
+
return await this.createJob(name, data, options, singletonOffset);
|
|
64
|
+
}
|
|
65
|
+
const states = {
|
|
66
|
+
active: 'active',
|
|
67
|
+
cancelled: 'cancelled',
|
|
68
|
+
completed: 'completed',
|
|
69
|
+
created: 'created',
|
|
70
|
+
expired: 'expired',
|
|
71
|
+
failed: 'failed',
|
|
72
|
+
retry: 'retry'
|
|
73
|
+
};
|
|
74
|
+
const insertJob = (schema) => `
|
|
75
|
+
INSERT INTO ${schema}.job (
|
|
76
|
+
id,
|
|
77
|
+
name,
|
|
78
|
+
priority,
|
|
79
|
+
state,
|
|
80
|
+
retryLimit,
|
|
81
|
+
startAfter,
|
|
82
|
+
expireIn,
|
|
83
|
+
data,
|
|
84
|
+
singletonKey,
|
|
85
|
+
singletonOn,
|
|
86
|
+
retryDelay,
|
|
87
|
+
retryBackoff,
|
|
88
|
+
keepUntil,
|
|
89
|
+
on_complete,
|
|
90
|
+
block_slot
|
|
91
|
+
)
|
|
92
|
+
SELECT
|
|
93
|
+
id,
|
|
94
|
+
name,
|
|
95
|
+
priority,
|
|
96
|
+
state,
|
|
97
|
+
retryLimit,
|
|
98
|
+
startAfter,
|
|
99
|
+
expireIn,
|
|
100
|
+
data,
|
|
101
|
+
singletonKey,
|
|
102
|
+
singletonOn,
|
|
103
|
+
retryDelay,
|
|
104
|
+
retryBackoff,
|
|
105
|
+
keepUntil,
|
|
106
|
+
on_complete,
|
|
107
|
+
block_slot
|
|
108
|
+
FROM
|
|
109
|
+
( SELECT *,
|
|
110
|
+
CASE
|
|
111
|
+
WHEN right(keepUntilValue, 1) = 'Z' THEN CAST(keepUntilValue as timestamp with time zone)
|
|
112
|
+
ELSE startAfter + CAST(COALESCE(keepUntilValue,'0') as interval)
|
|
113
|
+
END as keepUntil
|
|
114
|
+
FROM
|
|
115
|
+
( SELECT *,
|
|
116
|
+
CASE
|
|
117
|
+
WHEN right(startAfterValue, 1) = 'Z' THEN CAST(startAfterValue as timestamp with time zone)
|
|
118
|
+
ELSE now() + CAST(COALESCE(startAfterValue,'0') as interval)
|
|
119
|
+
END as startAfter
|
|
120
|
+
FROM
|
|
121
|
+
( SELECT
|
|
122
|
+
$1::uuid as id,
|
|
123
|
+
$2::text as name,
|
|
124
|
+
$3::int as priority,
|
|
125
|
+
'${states.created}'::${schema}.job_state as state,
|
|
126
|
+
$4::int as retryLimit,
|
|
127
|
+
$5::text as startAfterValue,
|
|
128
|
+
CAST($6 as interval) as expireIn,
|
|
129
|
+
$7::jsonb as data,
|
|
130
|
+
$8::text as singletonKey,
|
|
131
|
+
CASE
|
|
132
|
+
WHEN $9::integer IS NOT NULL THEN 'epoch'::timestamp + '1 second'::interval * ($9 * floor((date_part('epoch', now()) + $10) / $9))
|
|
133
|
+
ELSE NULL
|
|
134
|
+
END as singletonOn,
|
|
135
|
+
$11::int as retryDelay,
|
|
136
|
+
$12::bool as retryBackoff,
|
|
137
|
+
$13::text as keepUntilValue,
|
|
138
|
+
$14::boolean as on_complete,
|
|
139
|
+
$15::int as block_slot
|
|
140
|
+
) j1
|
|
141
|
+
) j2
|
|
142
|
+
) j3
|
|
143
|
+
ON CONFLICT DO NOTHING
|
|
144
|
+
RETURNING id
|
|
145
|
+
`;
|
|
146
|
+
async function send(...args) {
|
|
147
|
+
const { name, data, options } = Attorney.checkSendArgs(args, this.manager.config);
|
|
148
|
+
return await this.createJob(name, data, options);
|
|
149
|
+
}
|
|
150
|
+
export const createPgBossExtension = (queryRunner) => {
|
|
151
|
+
const boss = new PgBoss({ db: new BossDb(queryRunner) });
|
|
152
|
+
boss.insertJobCommand = insertJob('pgboss');
|
|
153
|
+
boss.send = send;
|
|
154
|
+
boss.createJob = createJob;
|
|
155
|
+
return {
|
|
156
|
+
send(taskName, data, options) {
|
|
157
|
+
return boss.send(taskName, data, options);
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
};
|
|
161
|
+
//# sourceMappingURL=pgBoss.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pgBoss.js","sourceRoot":"","sources":["../../src/pgBoss.ts"],"names":[],"mappings":"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"}
|