mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-11 18:30:30 +00:00
92 lines
2.9 KiB
TypeScript
92 lines
2.9 KiB
TypeScript
import { Knex } from 'knex';
|
|
import { Inject, Injectable } from '@nestjs/common';
|
|
import { CommandAccountValidators } from './CommandAccountValidators.service';
|
|
import { Account } from './models/Account.model';
|
|
import { EventEmitter2 } from '@nestjs/event-emitter';
|
|
import { UnitOfWork } from '../Tenancy/TenancyDB/UnitOfWork.service';
|
|
import { events } from '@/common/events/events';
|
|
import { IAccountEventDeletedPayload } from './Accounts.types';
|
|
import { TenantModelProxy } from '../System/models/TenantBaseModel';
|
|
import { ERRORS } from './constants';
|
|
|
|
@Injectable()
|
|
export class DeleteAccount {
|
|
constructor(
|
|
@Inject(Account.name)
|
|
private accountModel: TenantModelProxy<typeof Account>,
|
|
|
|
private eventEmitter: EventEmitter2,
|
|
private uow: UnitOfWork,
|
|
private validator: CommandAccountValidators,
|
|
) {}
|
|
|
|
/**
|
|
* Authorize account delete.
|
|
* @param {number} accountId - Account id.
|
|
*/
|
|
private authorize = async (accountId: number, oldAccount: Account) => {
|
|
// Throw error if the account was predefined.
|
|
this.validator.throwErrorIfAccountPredefined(oldAccount);
|
|
};
|
|
|
|
/**
|
|
* Unlink the given parent account with children accounts.
|
|
* @param {number|number[]} parentAccountId -
|
|
*/
|
|
private async unassociateChildrenAccountsFromParent(
|
|
parentAccountId: number | number[],
|
|
trx?: Knex.Transaction,
|
|
) {
|
|
const accountsIds = Array.isArray(parentAccountId)
|
|
? parentAccountId
|
|
: [parentAccountId];
|
|
|
|
await this.accountModel()
|
|
.query(trx)
|
|
.whereIn('parent_account_id', accountsIds)
|
|
.patch({ parentAccountId: null });
|
|
}
|
|
|
|
/**
|
|
* Deletes the account from the storage.
|
|
* @param {number} accountId
|
|
* @param {Knex.Transaction} trx - Database transaction instance.
|
|
*/
|
|
public deleteAccount = async (
|
|
accountId: number,
|
|
trx?: Knex.Transaction,
|
|
): Promise<void> => {
|
|
// Retrieve account or not found service error.
|
|
const oldAccount = await this.accountModel().query().findById(accountId);
|
|
|
|
// Authorize before delete account.
|
|
await this.authorize(accountId, oldAccount);
|
|
|
|
// Deletes the account and associated transactions under UOW environment.
|
|
return this.uow.withTransaction(async (trx: Knex.Transaction) => {
|
|
// Triggers `onAccountDelete` event.
|
|
await this.eventEmitter.emitAsync(events.accounts.onDelete, {
|
|
trx,
|
|
oldAccount,
|
|
} as IAccountEventDeletedPayload);
|
|
|
|
// Unlink the parent account from children accounts.
|
|
await this.unassociateChildrenAccountsFromParent(accountId, trx);
|
|
|
|
// Deletes account by the given id.
|
|
await this.accountModel()
|
|
.query(trx)
|
|
.findById(accountId)
|
|
.deleteIfNoRelations({
|
|
type: ERRORS.ACCOUNT_HAS_ASSOCIATED_TRANSACTIONS,
|
|
});
|
|
// Triggers `onAccountDeleted` event.
|
|
await this.eventEmitter.emitAsync(events.accounts.onDeleted, {
|
|
accountId,
|
|
oldAccount,
|
|
trx,
|
|
} as IAccountEventDeletedPayload);
|
|
}, trx);
|
|
};
|
|
}
|