]>
Commit | Line | Data |
---|---|---|
65fcc311 | 1 | // TODO: import from ES6 when retry typing file will include errorFilter function |
4d4e5cd4 | 2 | import * as retry from 'async/retry' |
20494f12 | 3 | import * as Bluebird from 'bluebird' |
65fcc311 | 4 | import { logger } from './logger' |
4145c1c6 | 5 | |
69818c93 | 6 | type RetryTransactionWrapperOptions = { errorMessage: string, arguments?: any[] } |
0f91ae62 C |
7 | function retryTransactionWrapper <T> ( |
8 | functionToRetry: (...args) => Promise<T> | Bluebird<T>, | |
9 | options: RetryTransactionWrapperOptions | |
10 | ): Promise<T> { | |
4df023f2 C |
11 | const args = options.arguments ? options.arguments : [] |
12 | ||
0f91ae62 | 13 | return transactionRetryer<T>(callback => { |
075f16ca | 14 | functionToRetry.apply(this, args) |
0f91ae62 | 15 | .then((result: T) => callback(null, result)) |
6fcd19ba | 16 | .catch(err => callback(err)) |
075f16ca | 17 | }) |
6fcd19ba | 18 | .catch(err => { |
ad0997ad | 19 | logger.error(options.errorMessage, err) |
20494f12 | 20 | throw err |
6fcd19ba | 21 | }) |
4df023f2 C |
22 | } |
23 | ||
0f91ae62 C |
24 | function transactionRetryer <T> (func: (err: any, data: T) => any) { |
25 | return new Promise<T>((res, rej) => { | |
6fcd19ba C |
26 | retry({ |
27 | times: 5, | |
4df023f2 | 28 | |
075f16ca | 29 | errorFilter: err => { |
6fcd19ba C |
30 | const willRetry = (err.name === 'SequelizeDatabaseError') |
31 | logger.debug('Maybe retrying the transaction function.', { willRetry }) | |
32 | return willRetry | |
33 | } | |
20494f12 | 34 | }, func, (err, data) => err ? rej(err) : res(data)) |
4df023f2 C |
35 | }) |
36 | } | |
37 | ||
38 | // --------------------------------------------------------------------------- | |
39 | ||
65fcc311 | 40 | export { |
65fcc311 | 41 | retryTransactionWrapper, |
65fcc311 C |
42 | transactionRetryer |
43 | } |