|
@@ -3,16 +3,20 @@ import { DomainEventHandlerInterface, ItemDumpedEvent } from '@standardnotes/dom
|
|
import { DumpRepositoryInterface } from '../Dump/DumpRepositoryInterface'
|
|
import { DumpRepositoryInterface } from '../Dump/DumpRepositoryInterface'
|
|
import { RevisionRepositoryResolverInterface } from '../Revision/RevisionRepositoryResolverInterface'
|
|
import { RevisionRepositoryResolverInterface } from '../Revision/RevisionRepositoryResolverInterface'
|
|
import { RoleNameCollection } from '@standardnotes/domain-core'
|
|
import { RoleNameCollection } from '@standardnotes/domain-core'
|
|
|
|
+import { Logger } from 'winston'
|
|
|
|
|
|
export class ItemDumpedEventHandler implements DomainEventHandlerInterface {
|
|
export class ItemDumpedEventHandler implements DomainEventHandlerInterface {
|
|
constructor(
|
|
constructor(
|
|
private dumpRepository: DumpRepositoryInterface,
|
|
private dumpRepository: DumpRepositoryInterface,
|
|
private revisionRepositoryResolver: RevisionRepositoryResolverInterface,
|
|
private revisionRepositoryResolver: RevisionRepositoryResolverInterface,
|
|
|
|
+ private logger: Logger,
|
|
) {}
|
|
) {}
|
|
|
|
|
|
async handle(event: ItemDumpedEvent): Promise<void> {
|
|
async handle(event: ItemDumpedEvent): Promise<void> {
|
|
const revision = await this.dumpRepository.getRevisionFromDumpPath(event.payload.fileDumpPath)
|
|
const revision = await this.dumpRepository.getRevisionFromDumpPath(event.payload.fileDumpPath)
|
|
if (revision === null) {
|
|
if (revision === null) {
|
|
|
|
+ this.logger.error(`Revision not found for dump path ${event.payload.fileDumpPath}`)
|
|
|
|
+
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
|
|
|
|
return
|
|
return
|
|
@@ -20,6 +24,8 @@ export class ItemDumpedEventHandler implements DomainEventHandlerInterface {
|
|
|
|
|
|
const roleNamesOrError = RoleNameCollection.create(event.payload.roleNames)
|
|
const roleNamesOrError = RoleNameCollection.create(event.payload.roleNames)
|
|
if (roleNamesOrError.isFailed()) {
|
|
if (roleNamesOrError.isFailed()) {
|
|
|
|
+ this.logger.error(`Invalid role names ${event.payload.roleNames}`)
|
|
|
|
+
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
|
|
|
|
return
|
|
return
|
|
@@ -28,7 +34,10 @@ export class ItemDumpedEventHandler implements DomainEventHandlerInterface {
|
|
|
|
|
|
const revisionRepository = this.revisionRepositoryResolver.resolve(roleNames)
|
|
const revisionRepository = this.revisionRepositoryResolver.resolve(roleNames)
|
|
|
|
|
|
- await revisionRepository.insert(revision)
|
|
|
|
|
|
+ const successfullyInserted = await revisionRepository.insert(revision)
|
|
|
|
+ if (!successfullyInserted) {
|
|
|
|
+ this.logger.error(`Could not insert revision ${revision.id.toString()}`)
|
|
|
|
+ }
|
|
|
|
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
await this.dumpRepository.removeDump(event.payload.fileDumpPath)
|
|
}
|
|
}
|