({
id,
errorMessage,
provider = 'stripe',
logger,
}: {
id: string
errorMessage: string
provider: string
logger: Logger
})
| 6 | import type { Logger } from '@codebuff/common/types/contracts/logger' |
| 7 | |
| 8 | export async function logSyncFailure({ |
| 9 | id, |
| 10 | errorMessage, |
| 11 | provider = 'stripe', |
| 12 | logger, |
| 13 | }: { |
| 14 | id: string |
| 15 | errorMessage: string |
| 16 | provider: string |
| 17 | logger: Logger |
| 18 | }): Promise<void> { |
| 19 | try { |
| 20 | await db |
| 21 | .insert(schema.syncFailure) |
| 22 | .values({ |
| 23 | id, |
| 24 | provider, |
| 25 | last_error: errorMessage, |
| 26 | last_attempt_at: new Date(), |
| 27 | }) |
| 28 | .onConflictDoUpdate({ |
| 29 | target: schema.syncFailure.id, |
| 30 | set: { |
| 31 | last_error: errorMessage, |
| 32 | last_attempt_at: new Date(), |
| 33 | retry_count: sql`${schema.syncFailure.retry_count} + 1`, |
| 34 | }, |
| 35 | }) |
| 36 | } catch (dbError) { |
| 37 | logger.error( |
| 38 | { id, provider, error: dbError }, |
| 39 | 'Failed to log sync failure to database.', |
| 40 | ) |
| 41 | } |
| 42 | } |
no test coverage detected