mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-18 22:00:31 +00:00
feat: pause/resume bank account feeds syncing
This commit is contained in:
@@ -1,7 +1,6 @@
|
|||||||
import { Inject, Service } from 'typedi';
|
import { Inject, Service } from 'typedi';
|
||||||
import { NextFunction, Request, Response, Router } from 'express';
|
import { NextFunction, Request, Response, Router } from 'express';
|
||||||
import BaseController from '@/api/controllers/BaseController';
|
import BaseController from '@/api/controllers/BaseController';
|
||||||
import { CashflowApplication } from '@/services/Cashflow/CashflowApplication';
|
|
||||||
import { GetBankAccountSummary } from '@/services/Banking/BankAccounts/GetBankAccountSummary';
|
import { GetBankAccountSummary } from '@/services/Banking/BankAccounts/GetBankAccountSummary';
|
||||||
import { BankAccountsApplication } from '@/services/Banking/BankAccounts/BankAccountsApplication';
|
import { BankAccountsApplication } from '@/services/Banking/BankAccounts/BankAccountsApplication';
|
||||||
|
|
||||||
@@ -25,6 +24,14 @@ export class BankAccountsController extends BaseController {
|
|||||||
this.disconnectBankAccount.bind(this)
|
this.disconnectBankAccount.bind(this)
|
||||||
);
|
);
|
||||||
router.post('/:bankAccountId/update', this.refreshBankAccount.bind(this));
|
router.post('/:bankAccountId/update', this.refreshBankAccount.bind(this));
|
||||||
|
router.post(
|
||||||
|
'/:bankAccountId/pause_feeds',
|
||||||
|
this.pauseBankAccountFeeds.bind(this)
|
||||||
|
);
|
||||||
|
router.post(
|
||||||
|
'/:bankAccountId/resume_feeds',
|
||||||
|
this.resumeBankAccountFeeds.bind(this)
|
||||||
|
);
|
||||||
|
|
||||||
return router;
|
return router;
|
||||||
}
|
}
|
||||||
@@ -109,4 +116,42 @@ export class BankAccountsController extends BaseController {
|
|||||||
next(error);
|
next(error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async resumeBankAccountFeeds(
|
||||||
|
req: Request<{ bankAccountId: number }>,
|
||||||
|
res: Response,
|
||||||
|
next: NextFunction
|
||||||
|
) {
|
||||||
|
const { bankAccountId } = req.params;
|
||||||
|
const { tenantId } = req;
|
||||||
|
|
||||||
|
try {
|
||||||
|
await this.bankAccountsApp.resumeBankAccount(tenantId, bankAccountId);
|
||||||
|
|
||||||
|
return res.status(200).send({
|
||||||
|
message: '',
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
next(error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async pauseBankAccountFeeds(
|
||||||
|
req: Request<{ bankAccountId: number }>,
|
||||||
|
res: Response,
|
||||||
|
next: NextFunction
|
||||||
|
) {
|
||||||
|
const { bankAccountId } = req.params;
|
||||||
|
const { tenantId } = req;
|
||||||
|
|
||||||
|
try {
|
||||||
|
await this.bankAccountsApp.pauseBankAccount(tenantId, bankAccountId);
|
||||||
|
|
||||||
|
return res.status(200).send({
|
||||||
|
message: '',
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
next(error);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import { Inject, Service } from 'typedi';
|
import { Inject, Service } from 'typedi';
|
||||||
import { DisconnectBankAccount } from './DisconnectBankAccount';
|
import { DisconnectBankAccount } from './DisconnectBankAccount';
|
||||||
import { RefreshBankAccountService } from './RefreshBankAccount';
|
import { RefreshBankAccountService } from './RefreshBankAccount';
|
||||||
|
import { ResumeBankAccountFeeds } from './PauseBankAccountFeeds';
|
||||||
|
|
||||||
@Service()
|
@Service()
|
||||||
export class BankAccountsApplication {
|
export class BankAccountsApplication {
|
||||||
@@ -10,6 +11,12 @@ export class BankAccountsApplication {
|
|||||||
@Inject()
|
@Inject()
|
||||||
private refreshBankAccountService: RefreshBankAccountService;
|
private refreshBankAccountService: RefreshBankAccountService;
|
||||||
|
|
||||||
|
@Inject()
|
||||||
|
private resumeBankAccountFeedsService: ResumeBankAccountFeeds;
|
||||||
|
|
||||||
|
@Inject()
|
||||||
|
private pauseBankAccountFeedsService: ResumeBankAccountFeeds;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disconnects the given bank account.
|
* Disconnects the given bank account.
|
||||||
* @param {number} tenantId
|
* @param {number} tenantId
|
||||||
@@ -27,7 +34,7 @@ export class BankAccountsApplication {
|
|||||||
* Refresh the bank transactions of the given bank account.
|
* Refresh the bank transactions of the given bank account.
|
||||||
* @param {number} tenantId
|
* @param {number} tenantId
|
||||||
* @param {number} bankAccountId
|
* @param {number} bankAccountId
|
||||||
* @returns {Promise<void>}
|
* @returns {Promise<void>}
|
||||||
*/
|
*/
|
||||||
async refreshBankAccount(tenantId: number, bankAccountId: number) {
|
async refreshBankAccount(tenantId: number, bankAccountId: number) {
|
||||||
return this.refreshBankAccountService.refreshBankAccount(
|
return this.refreshBankAccountService.refreshBankAccount(
|
||||||
@@ -35,4 +42,30 @@ export class BankAccountsApplication {
|
|||||||
bankAccountId
|
bankAccountId
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pauses the feeds sync of the given bank account.
|
||||||
|
* @param {number} tenantId
|
||||||
|
* @param {number} bankAccountId
|
||||||
|
* @returns {Promise<void>}
|
||||||
|
*/
|
||||||
|
async pauseBankAccount(tenantId: number, bankAccountId: number) {
|
||||||
|
return this.pauseBankAccountFeedsService.resumeBankAccountFeeds(
|
||||||
|
tenantId,
|
||||||
|
bankAccountId
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resumes the feeds sync of the given bank account.
|
||||||
|
* @param {number} tenantId
|
||||||
|
* @param {number} bankAccountId
|
||||||
|
* @returns {Promise<void>}
|
||||||
|
*/
|
||||||
|
async resumeBankAccount(tenantId: number, bankAccountId: number) {
|
||||||
|
return this.resumeBankAccountFeedsService.resumeBankAccountFeeds(
|
||||||
|
tenantId,
|
||||||
|
bankAccountId
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
import { Service } from 'typedi';
|
||||||
|
|
||||||
|
@Service()
|
||||||
|
export class ResumeBankAccountFeeds {
|
||||||
|
public resumeBankAccountFeeds(tenantId: number, bankAccountId: number) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
import { Service } from "typedi";
|
||||||
|
|
||||||
|
@Service()
|
||||||
|
export class ResumeBankAccountFeeds {
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {number} tenantId
|
||||||
|
* @param {number} bankAccountId
|
||||||
|
*/
|
||||||
|
public resumeBankAccountFeeds(tenantId: number, bankAccountId: number) {}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user