]>
Commit | Line | Data |
---|---|---|
1 | import * as retry from 'async/retry' | |
2 | import * as Bluebird from 'bluebird' | |
3 | import { Model } from 'sequelize-typescript' | |
4 | import { logger } from './logger' | |
5 | ||
6 | type RetryTransactionWrapperOptions = { errorMessage: string, arguments?: any[] } | |
7 | function retryTransactionWrapper <T> ( | |
8 | functionToRetry: (...args) => Promise<T> | Bluebird<T>, | |
9 | options: RetryTransactionWrapperOptions | |
10 | ): Promise<T> { | |
11 | const args = options.arguments ? options.arguments : [] | |
12 | ||
13 | return transactionRetryer<T>(callback => { | |
14 | functionToRetry.apply(this, args) | |
15 | .then((result: T) => callback(null, result)) | |
16 | .catch(err => callback(err)) | |
17 | }) | |
18 | .catch(err => { | |
19 | console.error(err) | |
20 | logger.error(options.errorMessage, err) | |
21 | throw err | |
22 | }) | |
23 | } | |
24 | ||
25 | function transactionRetryer <T> (func: (err: any, data: T) => any) { | |
26 | return new Promise<T>((res, rej) => { | |
27 | retry({ | |
28 | times: 5, | |
29 | ||
30 | errorFilter: err => { | |
31 | const willRetry = (err.name === 'SequelizeDatabaseError') | |
32 | logger.debug('Maybe retrying the transaction function.', { willRetry }) | |
33 | return willRetry | |
34 | } | |
35 | }, func, (err, data) => err ? rej(err) : res(data)) | |
36 | }) | |
37 | } | |
38 | ||
39 | function updateInstanceWithAnother <T> (instanceToUpdate: Model<T>, baseInstance: Model<T>) { | |
40 | const obj = baseInstance.toJSON() | |
41 | ||
42 | for (const key of Object.keys(obj)) { | |
43 | instanceToUpdate.set(key, obj[key]) | |
44 | } | |
45 | } | |
46 | ||
47 | // --------------------------------------------------------------------------- | |
48 | ||
49 | export { | |
50 | retryTransactionWrapper, | |
51 | transactionRetryer, | |
52 | updateInstanceWithAnother | |
53 | } |