gemcap-be-common 1.2.140 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/classes/bank-transaction-item.d.ts +17 -0
  2. package/classes/bank-transaction-item.js +64 -0
  3. package/classes/bank-transaction-item.ts +66 -0
  4. package/classes/bank-uploaded-transaction.d.ts +17 -0
  5. package/classes/bank-uploaded-transaction.js +35 -0
  6. package/classes/bank-uploaded-transaction.ts +35 -0
  7. package/classes/inventory-item.d.ts +41 -0
  8. package/classes/inventory-item.js +44 -0
  9. package/classes/inventory-item.ts +63 -0
  10. package/classes/payable-account-item.d.ts +22 -0
  11. package/classes/payable-account-item.js +27 -0
  12. package/classes/payable-account-item.ts +35 -0
  13. package/classes/quickbook-item.d.ts +37 -0
  14. package/classes/quickbook-item.js +51 -0
  15. package/classes/quickbook-item.ts +59 -0
  16. package/classes/receivable-item.d.ts +26 -0
  17. package/classes/receivable-item.js +28 -0
  18. package/classes/receivable-item.ts +38 -0
  19. package/constants/date-formats.contsants.d.ts +1 -0
  20. package/constants/date-formats.contsants.js +4 -0
  21. package/constants/date-formats.contsants.ts +1 -0
  22. package/db/brokers.db.d.ts +185 -0
  23. package/db/brokers.db.js +35 -2
  24. package/db/brokers.db.ts +34 -1
  25. package/db/collateral-adjustments.db.d.ts +34 -0
  26. package/db/collateral-adjustments.db.js +52 -0
  27. package/db/collateral-adjustments.db.ts +54 -0
  28. package/db/collaterals.db.d.ts +1 -1
  29. package/db/equipment.db.d.ts +40 -0
  30. package/db/equipment.db.js +55 -0
  31. package/db/equipment.db.ts +56 -0
  32. package/db/financial-spreading.db.ts +2 -1
  33. package/db/groups.d.ts +5 -0
  34. package/db/groups.js +57 -0
  35. package/db/groups.ts +52 -0
  36. package/db/inventories.d.ts +91 -0
  37. package/db/inventories.js +449 -0
  38. package/db/inventories.ts +481 -0
  39. package/db/inventory-availability.d.ts +3 -0
  40. package/db/inventory-availability.js +103 -0
  41. package/db/inventory-availability.ts +113 -0
  42. package/db/new-summary.d.ts +31 -0
  43. package/db/new-summary.js +1295 -0
  44. package/db/new-summary.ts +1509 -0
  45. package/db/payable-accounts.d.ts +30 -0
  46. package/db/payable-accounts.js +55 -0
  47. package/db/payable-accounts.ts +50 -0
  48. package/db/reserve.db.d.ts +34 -0
  49. package/db/reserve.db.js +52 -0
  50. package/db/reserve.db.ts +48 -0
  51. package/db/uploads.db.d.ts +2 -0
  52. package/db/uploads.db.js +29 -0
  53. package/db/uploads.db.ts +24 -0
  54. package/helpers/main.helper.d.ts +31 -0
  55. package/helpers/main.helper.js +63 -0
  56. package/helpers/main.helper.ts +63 -0
  57. package/models/AccountPayableItem.model.d.ts +6 -6
  58. package/models/AllocatedBankTransaction.model.d.ts +54 -0
  59. package/models/AllocatedBankTransaction.model.js +70 -0
  60. package/models/AllocatedBankTransaction.model.ts +94 -0
  61. package/models/AllocatedData.model.d.ts +33 -0
  62. package/models/AllocatedData.model.js +19 -0
  63. package/models/AllocatedData.model.ts +24 -0
  64. package/models/BBCDate.model.d.ts +3 -3
  65. package/models/BBCSheet.model.d.ts +3 -3
  66. package/models/Banks.model.d.ts +3 -3
  67. package/models/Borrower.model.d.ts +3 -3
  68. package/models/BorrowerData.model.d.ts +3 -3
  69. package/models/BorrowerDataInsurance.model.d.ts +3 -3
  70. package/models/BorrowerDataTerm.model.d.ts +3 -3
  71. package/models/BorrowerSummary.model.js +1 -1
  72. package/models/BorrowerSummary.model.ts +1 -1
  73. package/models/CalandarDay.model.d.ts +40 -0
  74. package/models/CalandarDay.model.js +47 -0
  75. package/models/CalandarDay.model.ts +61 -0
  76. package/models/CashAllocationProduct.model.d.ts +119 -0
  77. package/models/CashAllocationProduct.model.js +102 -0
  78. package/models/CashAllocationProduct.model.ts +112 -0
  79. package/models/CashAllocationReference.model.d.ts +37 -0
  80. package/models/CashAllocationReference.model.js +27 -0
  81. package/models/CashAllocationReference.model.ts +40 -0
  82. package/models/CollateralAdjustment.model.d.ts +51 -0
  83. package/models/CollateralAdjustment.model.js +61 -0
  84. package/models/CollateralAdjustment.model.ts +98 -0
  85. package/models/Company.model.d.ts +35 -0
  86. package/models/Company.model.js +18 -0
  87. package/models/Company.model.ts +29 -0
  88. package/models/CustomerAPGroup.model.d.ts +32 -0
  89. package/models/CustomerAPGroup.model.js +24 -0
  90. package/models/CustomerAPGroup.model.ts +31 -0
  91. package/models/Equipment.model.d.ts +53 -0
  92. package/models/Equipment.model.js +140 -0
  93. package/models/Equipment.model.ts +172 -0
  94. package/models/FinancialCompliance.model.d.ts +39 -0
  95. package/models/FinancialCompliance.model.js +64 -0
  96. package/models/FinancialCompliance.model.ts +78 -0
  97. package/models/FinancialComplianceBorrower.model.d.ts +58 -0
  98. package/models/FinancialComplianceBorrower.model.js +82 -0
  99. package/models/FinancialComplianceBorrower.model.ts +118 -0
  100. package/models/FinancialIndexes.model.d.ts +36 -0
  101. package/models/FinancialIndexes.model.js +27 -0
  102. package/models/FinancialIndexes.model.ts +37 -0
  103. package/models/Inventory.model.d.ts +18 -18
  104. package/models/InventoryAvailability.model.d.ts +21 -21
  105. package/models/InventoryAvailabilityItem.model.d.ts +6 -6
  106. package/models/InventoryItem.model.d.ts +24 -24
  107. package/models/InventoryManualEntry.model.d.ts +9 -9
  108. package/models/InventorySeasonalRates.model.d.ts +3 -3
  109. package/models/LoanBroker.model.d.ts +3 -3
  110. package/models/LoanCharges.model.d.ts +12 -12
  111. package/models/LoanProducts.model.d.ts +9 -9
  112. package/models/LoanStatementStatus.model.d.ts +35 -0
  113. package/models/LoanStatementStatus.model.js +34 -0
  114. package/models/LoanStatementStatus.model.ts +45 -0
  115. package/models/LoanStatementTransaction.model.d.ts +9 -9
  116. package/models/LoanTransactionFile.model.d.ts +41 -0
  117. package/models/LoanTransactionFile.model.js +44 -0
  118. package/models/LoanTransactionFile.model.ts +61 -0
  119. package/models/MappedGroup.model.d.ts +37 -0
  120. package/models/MappedGroup.model.js +33 -0
  121. package/models/MappedGroup.model.ts +46 -0
  122. package/models/MonthEndData.Model.d.ts +41 -0
  123. package/models/MonthEndData.Model.js +42 -0
  124. package/models/MonthEndData.Model.ts +53 -0
  125. package/models/OrganizationEmails.model.d.ts +44 -0
  126. package/models/OrganizationEmails.model.js +40 -0
  127. package/models/OrganizationEmails.model.ts +54 -0
  128. package/models/ProductBroker.model.d.ts +9 -9
  129. package/models/QuickbooksAccount.model.d.ts +39 -0
  130. package/models/QuickbooksAccount.model.js +43 -0
  131. package/models/QuickbooksAccount.model.ts +57 -0
  132. package/models/Receivable.model.d.ts +12 -12
  133. package/models/ReceivableAvailability.model.d.ts +54 -54
  134. package/models/ReceivableAvailabilityItem.model.d.ts +57 -57
  135. package/models/ReceivableItem.model.d.ts +6 -6
  136. package/models/Reserve.model.d.ts +51 -0
  137. package/models/Reserve.model.js +96 -0
  138. package/models/Reserve.model.ts +125 -0
  139. package/models/TermLoan.model.d.ts +3 -3
  140. package/models/TermLoanCalculated.model.d.ts +6 -6
  141. package/models/TransactionAttachedFile.Model.d.ts +35 -0
  142. package/models/TransactionAttachedFile.Model.js +37 -0
  143. package/models/TransactionAttachedFile.Model.ts +48 -0
  144. package/models/UploadedBankTransaction.model.d.ts +56 -0
  145. package/models/UploadedBankTransaction.model.js +78 -0
  146. package/models/UploadedBankTransaction.model.ts +110 -0
  147. package/models/UploadedData.model.d.ts +36 -0
  148. package/models/UploadedData.model.js +23 -0
  149. package/models/UploadedData.model.ts +35 -0
  150. package/models/UploadedFile.model.d.ts +40 -0
  151. package/models/UploadedFile.model.js +41 -0
  152. package/models/UploadedFile.model.ts +57 -0
  153. package/models/UploadedSheet.model.d.ts +46 -0
  154. package/models/UploadedSheet.model.js +27 -0
  155. package/models/UploadedSheet.model.ts +51 -0
  156. package/package.json +10 -1
  157. package/repositories/globals.repository.d.ts +8 -0
  158. package/repositories/globals.repository.js +24 -0
  159. package/repositories/globals.repository.ts +21 -0
  160. package/services/attached-files.service.d.ts +57 -0
  161. package/services/attached-files.service.js +103 -0
  162. package/services/attached-files.service.ts +123 -0
  163. package/services/availability.service.d.ts +77 -0
  164. package/services/availability.service.js +897 -0
  165. package/services/availability.service.ts +1034 -0
  166. package/services/bank-uploaded-transactions.service.d.ts +33 -0
  167. package/services/bank-uploaded-transactions.service.js +430 -0
  168. package/services/bank-uploaded-transactions.service.ts +475 -0
  169. package/services/banks.service.d.ts +36 -0
  170. package/services/banks.service.js +91 -0
  171. package/services/banks.service.ts +95 -0
  172. package/services/borrower-summary.service.d.ts +35 -0
  173. package/services/borrower-summary.service.js +310 -0
  174. package/services/borrower-summary.service.ts +334 -0
  175. package/services/borrowers.service.d.ts +103 -0
  176. package/services/borrowers.service.js +268 -0
  177. package/services/borrowers.service.ts +302 -0
  178. package/services/brokers.service.d.ts +212 -0
  179. package/services/brokers.service.js +160 -0
  180. package/services/brokers.service.ts +200 -0
  181. package/services/calendar.service.d.ts +53 -0
  182. package/services/calendar.service.js +108 -0
  183. package/services/calendar.service.ts +128 -0
  184. package/services/cash-allocation.service.d.ts +40 -0
  185. package/services/cash-allocation.service.js +92 -0
  186. package/services/cash-allocation.service.ts +105 -0
  187. package/services/collateral-adjustments.service.d.ts +38 -0
  188. package/services/collateral-adjustments.service.js +82 -0
  189. package/services/collateral-adjustments.service.ts +95 -0
  190. package/services/collaterals.service.d.ts +69 -0
  191. package/services/collaterals.service.js +279 -0
  192. package/services/collaterals.service.ts +319 -0
  193. package/services/companies.service.d.ts +5 -0
  194. package/services/companies.service.js +21 -0
  195. package/services/companies.service.ts +23 -0
  196. package/services/compliance-borrowers.service.d.ts +152 -0
  197. package/services/compliance-borrowers.service.js +569 -0
  198. package/services/compliance-borrowers.service.ts +617 -0
  199. package/services/equipment.service.d.ts +42 -0
  200. package/services/equipment.service.js +120 -0
  201. package/services/equipment.service.ts +149 -0
  202. package/services/file-manager.service.d.ts +44 -0
  203. package/services/file-manager.service.js +120 -0
  204. package/services/file-manager.service.ts +146 -0
  205. package/services/financial-compliance.service.d.ts +58 -0
  206. package/services/financial-compliance.service.js +281 -0
  207. package/services/financial-compliance.service.ts +309 -0
  208. package/services/financial-indexes.service.d.ts +20 -0
  209. package/services/financial-indexes.service.js +241 -0
  210. package/services/financial-indexes.service.ts +257 -0
  211. package/services/financial-spreading.service.d.ts +74 -0
  212. package/services/financial-spreading.service.js +450 -0
  213. package/services/financial-spreading.service.ts +517 -0
  214. package/services/globals.service.d.ts +5 -0
  215. package/services/globals.service.js +11 -0
  216. package/services/globals.service.ts +8 -0
  217. package/services/groups.service.d.ts +39 -0
  218. package/services/groups.service.js +65 -0
  219. package/services/groups.service.ts +64 -0
  220. package/services/inventory-availability.service.d.ts +13 -0
  221. package/services/inventory-availability.service.js +170 -0
  222. package/services/inventory-availability.service.ts +187 -0
  223. package/services/inventory.service.d.ts +118 -0
  224. package/services/inventory.service.js +239 -0
  225. package/services/inventory.service.ts +276 -0
  226. package/services/loan-charges.service.d.ts +83 -0
  227. package/services/loan-charges.service.js +343 -0
  228. package/services/loan-charges.service.ts +396 -0
  229. package/services/loan-payments.service.d.ts +94 -0
  230. package/services/loan-payments.service.js +485 -0
  231. package/services/loan-payments.service.ts +541 -0
  232. package/services/loan-products.service.d.ts +12 -0
  233. package/services/loan-products.service.js +55 -0
  234. package/services/loan-products.service.ts +58 -0
  235. package/services/loan-statement-balance.service.d.ts +16 -0
  236. package/services/loan-statement-balance.service.js +106 -0
  237. package/services/loan-statement-balance.service.ts +113 -0
  238. package/services/loan-statement-effects.service.d.ts +8 -0
  239. package/services/loan-statement-effects.service.js +42 -0
  240. package/services/loan-statement-effects.service.ts +41 -0
  241. package/services/loan-statement-status.service.d.ts +208 -0
  242. package/services/loan-statement-status.service.js +159 -0
  243. package/services/loan-statement-status.service.ts +177 -0
  244. package/services/loan-statement.service.d.ts +186 -0
  245. package/services/loan-statement.service.js +935 -0
  246. package/services/loan-statement.service.ts +1040 -0
  247. package/services/loan-transactions.service.d.ts +169 -0
  248. package/services/loan-transactions.service.js +941 -0
  249. package/services/loan-transactions.service.ts +1042 -0
  250. package/services/lock.service.d.ts +6 -0
  251. package/services/lock.service.js +45 -0
  252. package/services/lock.service.ts +45 -0
  253. package/services/manual-entry.service.d.ts +20 -0
  254. package/services/manual-entry.service.js +186 -0
  255. package/services/manual-entry.service.ts +201 -0
  256. package/services/month-end-data.service.d.ts +34 -0
  257. package/services/month-end-data.service.js +30 -0
  258. package/services/month-end-data.service.ts +35 -0
  259. package/services/nodemailer.service.d.ts +96 -0
  260. package/services/nodemailer.service.js +689 -0
  261. package/services/nodemailer.service.ts +774 -0
  262. package/services/organization-emails.service.d.ts +31 -0
  263. package/services/organization-emails.service.js +10 -0
  264. package/services/organization-emails.service.ts +7 -0
  265. package/services/organizations.service.d.ts +34 -0
  266. package/services/organizations.service.js +74 -0
  267. package/services/organizations.service.ts +84 -0
  268. package/services/pdf.service.d.ts +61 -0
  269. package/services/pdf.service.js +547 -0
  270. package/services/pdf.service.ts +642 -0
  271. package/services/quickbooks.service.d.ts +99 -0
  272. package/services/quickbooks.service.js +640 -0
  273. package/services/quickbooks.service.ts +734 -0
  274. package/services/reports/investor-summary.service.d.ts +28 -0
  275. package/services/reports/investor-summary.service.js +136 -0
  276. package/services/reports/investor-summary.service.ts +159 -0
  277. package/services/reports.service.d.ts +126 -0
  278. package/services/reports.service.js +584 -0
  279. package/services/reports.service.ts +702 -0
  280. package/services/reserve.service.d.ts +37 -0
  281. package/services/reserve.service.js +76 -0
  282. package/services/reserve.service.ts +79 -0
  283. package/services/sentry.service.d.ts +11 -0
  284. package/services/sentry.service.js +49 -0
  285. package/services/sentry.service.ts +33 -0
  286. package/services/signs.service.d.ts +69 -0
  287. package/services/signs.service.js +230 -0
  288. package/services/signs.service.ts +260 -0
  289. package/services/term-loan.service.d.ts +30 -0
  290. package/services/term-loan.service.js +614 -0
  291. package/services/term-loan.service.ts +696 -0
  292. package/services/uploads.service.d.ts +134 -0
  293. package/services/uploads.service.js +587 -0
  294. package/services/uploads.service.ts +643 -0
  295. package/services/user-logs.service.d.ts +23 -0
  296. package/services/user-logs.service.js +160 -0
  297. package/services/user-logs.service.ts +177 -0
  298. package/services/users.service.d.ts +4 -4
  299. package/services/yield.service.d.ts +46 -0
  300. package/services/yield.service.js +42 -12
  301. package/services/yield.service.ts +38 -8
  302. package/tsconfig.json +5 -5
  303. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,319 @@
1
+ import mongoose from 'mongoose';
2
+ import _ from 'lodash';
3
+
4
+ import { ECollaterals } from '../enums/collaterals.enum';
5
+ import { IPaginatorOptions, IUploadedItems } from '../interfaces/collaterals.interface';
6
+ import { BBCDateModel, IBBCDateDoc, ICreateBBCDate } from '../models/BBCDate.model';
7
+ import { BBCSheetModel, IBBCSheetDoc, IBBCSheetWithBBCDate } from '../models/BBCSheet.model';
8
+ import { IInventoryItem } from '../models/InventoryItem.model';
9
+ import { IReceivableItem } from '../models/ReceivableItem.model';
10
+ import {
11
+ IAccountPayableItem,
12
+ } from '../models/AccountPayableItem.model';
13
+ import { createBBCDate, getBBCDates, getBBCDatesByType } from '../db/bbcDates.db';
14
+ import { createBBCSheet, getBBCSheetsByType } from '../db/bbcSheets.db';
15
+ import {
16
+ collateralMap,
17
+ COLLATERALS_LOOKUP,
18
+ createQuery,
19
+ getCollateralListBySheetId,
20
+ ITEMS_PAGINATION,
21
+ } from '../db/collaterals.db';
22
+ import { getDigitsFrequencies } from '../helpers/numbers.helper';
23
+ import { getEnumKeyByEnumValue } from '../helpers/enums.helper';
24
+
25
+ import { GroupsService } from './groups.service';
26
+ import { UploadsService } from './uploads.service';
27
+
28
+ export class CollateralsService {
29
+
30
+ constructor(
31
+ private readonly _groupsService: GroupsService,
32
+ private readonly _uploadsService: UploadsService,
33
+ ) {
34
+ }
35
+
36
+ async findCollateralsByType(bbcDateId: string, collateralType: ECollaterals) {
37
+ const sheets = await this.findCollateralSheets(bbcDateId, collateralType);
38
+ return (await Promise.all(sheets.map(async (sheet) => {
39
+ return await this.getCollateralsBySheet(sheet);
40
+ })))
41
+ .reduce((acc, group) => [...acc, ...group], []);
42
+ }
43
+
44
+ async findCollaterals(collateralsId: string, group: boolean, paginatorOptions?: IPaginatorOptions) {
45
+ const sheet = await this.findCollateralSheetsById(collateralsId);
46
+ if (group) {
47
+ return await this.getCollateralsBySheet(sheet, paginatorOptions);
48
+ }
49
+ return await getCollateralListBySheetId(sheet, paginatorOptions);
50
+ }
51
+
52
+ async countCollateralItems(bbcSheetId: string) {
53
+ const sheet = await this.findCollateralSheetsById(bbcSheetId);
54
+ return await this.getCollateralItemTotal(sheet);
55
+ }
56
+
57
+ async findCollateralSheets(bbcDateId: string, collateralType: ECollaterals) {
58
+ return BBCSheetModel.find({ bbcDateId, dataType: collateralType });
59
+ }
60
+
61
+ async findCollateralSheetsById(collateralsId: string): Promise<IBBCSheetDoc> {
62
+ return BBCSheetModel.findById(collateralsId);
63
+ }
64
+
65
+ async findCollateralSheetByIdWithBBCDate(collateralsId: string) {
66
+ const bbcSheet: IBBCSheetWithBBCDate[] = await BBCSheetModel.aggregate([
67
+ {
68
+ $match: {
69
+ '_id': new mongoose.Types.ObjectId(collateralsId),
70
+ },
71
+ }, {
72
+ $lookup: {
73
+ 'from': 'bbcdates',
74
+ 'localField': 'bbcDateId',
75
+ 'foreignField': '_id',
76
+ 'as': 'bbcDate',
77
+ },
78
+ }, {
79
+ $unwind: {
80
+ 'path': '$bbcDate',
81
+ },
82
+ },
83
+ ]);
84
+ return bbcSheet.length ? bbcSheet[0] : null;
85
+ }
86
+
87
+ async findAllCollaterals(borrowerId: string, collateralTypes: ECollaterals[]) {
88
+ return getBBCDatesByType(borrowerId, collateralTypes);
89
+ }
90
+
91
+ async saveCollateralItems<T extends IInventoryItem | IReceivableItem | IAccountPayableItem>(uploadedItems: IUploadedItems<T>, collateralType: ECollaterals, shift = 0) {
92
+ const bbcDates = await getBBCDates(uploadedItems.borrowerId, uploadedItems.bbcDate);
93
+ const bbcSheets = await getBBCSheetsByType(bbcDates.map((bbcDate) => String(bbcDate._id)), collateralType);
94
+ const lastBBCDate = bbcDates.pop();
95
+ const lastBBCSheet = bbcSheets.find((bbcSheet) => (bbcSheet.fileName === uploadedItems.fileName) && (bbcSheet.sheetName === uploadedItems.sheetName));
96
+
97
+ let savedBBCDate;
98
+ if (!lastBBCDate) {
99
+ const newBBCDate = new BBCDateModel({
100
+ borrowerId: uploadedItems.borrowerId,
101
+ bbcDate: uploadedItems.bbcDate,
102
+ });
103
+ savedBBCDate = await newBBCDate.save();
104
+ } else {
105
+ savedBBCDate = lastBBCDate;
106
+ }
107
+
108
+ let savedBBCSheet;
109
+ if (!lastBBCSheet) {
110
+ const newBBCSheet = new BBCSheetModel({
111
+ bbcDateId: savedBBCDate._id,
112
+ dataType: collateralType,
113
+ fileName: uploadedItems.fileName,
114
+ sheetName: uploadedItems.sheetName,
115
+ });
116
+ savedBBCSheet = await newBBCSheet.save();
117
+ } else {
118
+ savedBBCSheet = bbcSheets.pop();
119
+ }
120
+
121
+ const orderedItems = uploadedItems.items.map((item, index) => ({
122
+ ...item,
123
+ order: index + shift,
124
+ }));
125
+ await Promise.all(orderedItems.map(async (item) => {
126
+ const newCollateralItem = new collateralMap[collateralType]({
127
+ bbcSheetId: savedBBCSheet._id,
128
+ order: item.order,
129
+ ...item,
130
+ });
131
+ await newCollateralItem.save();
132
+ }));
133
+ return savedBBCDate._id;
134
+ }
135
+
136
+ async getCollateralsBySheet(sheet: IBBCSheetDoc, paginatorOptions?: IPaginatorOptions) {
137
+
138
+ const groupFields = {
139
+ bbcDate: 'bbc.bbcDate',
140
+ borrowerId: 'bbc.borrowerId',
141
+ fileName: 'bbcSheet.fileName',
142
+ sheetName: 'bbcSheet.sheetName',
143
+ };
144
+
145
+ const { groupQueries, itemQueries, enumKey } = createQuery(groupFields, sheet.dataType);
146
+ const groupingQuery = { _id: '$bbcSheetId', ...groupQueries, items: { $push: itemQueries } };
147
+
148
+ const collateralSheets = await collateralMap[enumKey].aggregate([
149
+ {
150
+ $match: {
151
+ 'bbcSheetId': new mongoose.Types.ObjectId(sheet.id),
152
+ },
153
+ },
154
+ ...COLLATERALS_LOOKUP,
155
+ {
156
+ $sort: {
157
+ order: 1,
158
+ },
159
+ },
160
+ ...ITEMS_PAGINATION(paginatorOptions),
161
+ {
162
+ $group: groupingQuery,
163
+ },
164
+ ]);
165
+ if (collateralSheets.length === 0) {
166
+ const bbcDates = await BBCDateModel.aggregate<IBBCDateDoc>([
167
+ {
168
+ $match: {
169
+ '_id': sheet.bbcDateId,
170
+ },
171
+ },
172
+ ]);
173
+ if (bbcDates.length === 0) {
174
+ return [];
175
+ }
176
+ return [{
177
+ _id: sheet._id,
178
+ bbcDate: bbcDates[0].bbcDate,
179
+ borrowerId: bbcDates[0].borrowerId,
180
+ fileName: sheet.fileName,
181
+ sheetName: sheet.sheetName,
182
+ items: [],
183
+ }];
184
+ }
185
+ return collateralSheets;
186
+ }
187
+
188
+ async getCollateralItemTotal(sheet: IBBCSheetDoc) {
189
+ const enumKey = getEnumKeyByEnumValue(ECollaterals, sheet.dataType);
190
+ return collateralMap[enumKey].countDocuments(
191
+ {
192
+ 'bbcSheetId': new mongoose.Types.ObjectId(sheet.id),
193
+ },
194
+ );
195
+ }
196
+
197
+ getCollateralsBenford(collaterals: any[]) {
198
+ if (collaterals.length === 0) {
199
+ return [];
200
+ }
201
+ const eachInventoryBenfordResult = [];
202
+
203
+ collaterals[0]?.digitArrays.forEach((lastDigitsArray) => {
204
+ const digitsArrayWithoutZeros = lastDigitsArray.filter((digit) => digit !== '0');
205
+ const results = [];
206
+ const firstDigitFrequencies = getDigitsFrequencies(lastDigitsArray);
207
+
208
+ for (let n = 1; n <= 9; n++) {
209
+ const dataFrequency = firstDigitFrequencies[n];
210
+ const dataFrequencyPercent = (dataFrequency / digitsArrayWithoutZeros.length) * 100;
211
+ const dataFrequencyTotal = isNaN(dataFrequencyPercent) ? 0 : Math.round(dataFrequencyPercent * 100) / 100;
212
+ results.push(dataFrequencyTotal);
213
+ }
214
+ eachInventoryBenfordResult.push(results);
215
+ });
216
+ return {
217
+ _id: collaterals[0]._id,
218
+ bbcDates: collaterals[0].bbcDates,
219
+ confirmed: eachInventoryBenfordResult,
220
+ };
221
+ }
222
+
223
+ async countCollateralDocsByBBC(bbcIds: string[], collateralType: ECollaterals) {
224
+ const bbcSheets = await getBBCSheetsByType(bbcIds, collateralType);
225
+ const collateralModel = collateralMap[collateralType];
226
+ if (!collateralModel) {
227
+ console.error(`Could not find a model for ${collateralType}`);
228
+ return 0;
229
+ }
230
+ return collateralModel.countDocuments(
231
+ {
232
+ 'bbcSheetId': { $in: bbcSheets.map((bbcSheet) => bbcSheet._id) },
233
+ },
234
+ );
235
+
236
+ }
237
+
238
+ excludeNoDataColumns(data: any[], columns: string[]) {
239
+ return data.map((dataRow) => _.pick(dataRow, columns));
240
+ }
241
+
242
+ async addCustomerGroups(data: any[], borrowerId: string) {
243
+ const groupName = 'customers';
244
+ const groups = await this._groupsService.getBorrowerGroups(borrowerId, groupName);
245
+ return data.map((dataRow) => {
246
+ const foundGroup = groups[groupName].find((group) => group.items.includes(dataRow.customerTitle));
247
+ return {
248
+ ...dataRow,
249
+ customerGroup: foundGroup ? foundGroup.groupName : dataRow.customerTitle,
250
+ };
251
+ });
252
+ }
253
+
254
+ async getLatestBBC(borrowerId: string, bbcDate = new Date()) {
255
+ const bbcDateDocs = await BBCDateModel.aggregate<IBBCDateDoc>([
256
+ {
257
+ $match: {
258
+ 'borrowerId': new mongoose.Types.ObjectId(borrowerId),
259
+ 'bbcDate': { $lte: bbcDate },
260
+ },
261
+ }, {
262
+ $sort: {
263
+ 'bbcDate': -1,
264
+ },
265
+ }, {
266
+ $limit: 1,
267
+ },
268
+ ]);
269
+ if (bbcDateDocs.length === 0) {
270
+ return null;
271
+ }
272
+ return bbcDateDocs[0];
273
+ }
274
+
275
+ async gebNextBBC(borrowerId: string, bbcDate = new Date()) {
276
+ return BBCDateModel.aggregate<IBBCDateDoc>([
277
+ {
278
+ $match: {
279
+ 'borrowerId': new mongoose.Types.ObjectId(borrowerId),
280
+ 'bbcDate': { $gte: bbcDate },
281
+ },
282
+ }, {
283
+ $sort: {
284
+ 'bbcDate': -1,
285
+ },
286
+ },
287
+ ]);
288
+ }
289
+
290
+ async getLatestBBCDate(borrowerId: string) {
291
+ const latestBBC = await this.getLatestBBC(borrowerId);
292
+ if (!latestBBC) {
293
+ return { lastBBCDate: null, lastBBCId: null };
294
+ }
295
+ return { lastBBCDate: latestBBC.bbcDate, lastBBCId: latestBBC._id.toString() };
296
+ }
297
+
298
+ async createBBCDate(bbcDate: ICreateBBCDate) {
299
+ if (bbcDate.inventory || bbcDate.receivables) {
300
+ const existingBbcDates = await getBBCDates(bbcDate.borrowerId, bbcDate.date);
301
+ let existingBbcDate = existingBbcDates.length > 0 ? existingBbcDates[0] : null;
302
+ if (!existingBbcDate) {
303
+ existingBbcDate = await createBBCDate(bbcDate.borrowerId, bbcDate.date);
304
+ }
305
+ if (bbcDate.inventory) {
306
+ await createBBCSheet(existingBbcDate._id.toString(), 'INVENTORY');
307
+ }
308
+ if (bbcDate.receivables) {
309
+ await createBBCSheet(existingBbcDate._id.toString(), 'RECEIVABLE');
310
+ }
311
+ }
312
+ }
313
+
314
+ async deleteCollateralById(collateralId: string) {
315
+ const results = await BBCSheetModel.findByIdAndDelete(collateralId);
316
+ setTimeout(async () => await this._uploadsService.removeEmptyBBC(true), 500);
317
+ return results;
318
+ }
319
+ }
@@ -0,0 +1,5 @@
1
+ import { ICompany } from '../models/Company.model';
2
+ export declare class CompaniesService {
3
+ getCompanies(): Promise<ICompany[]>;
4
+ createCompanies(): Promise<void>;
5
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CompaniesService = void 0;
4
+ const Company_model_1 = require("../models/Company.model");
5
+ const main_helper_1 = require("../helpers/main.helper");
6
+ class CompaniesService {
7
+ async getCompanies() {
8
+ const companies = await Company_model_1.Company.find().sort({ name: 1 });
9
+ return companies.map((i) => (0, main_helper_1.removeFields)(i, main_helper_1.fieldsToUnset));
10
+ }
11
+ async createCompanies() {
12
+ const companies = [
13
+ { name: 'AssetCo' },
14
+ { name: 'OpCo' },
15
+ ];
16
+ await Promise.all(companies.map(async (company) => {
17
+ await Company_model_1.Company.findOneAndUpdate({ name: company.name }, { $setOnInsert: { name: company.name } }, { upsert: true, new: true });
18
+ }));
19
+ }
20
+ }
21
+ exports.CompaniesService = CompaniesService;
@@ -0,0 +1,23 @@
1
+ import { Company, ICompany } from '../models/Company.model';
2
+ import { fieldsToUnset, removeFields } from '../helpers/main.helper';
3
+
4
+ export class CompaniesService {
5
+ async getCompanies() {
6
+ const companies = await Company.find().sort({ name: 1 });
7
+ return companies.map((i) => removeFields<ICompany>(i, fieldsToUnset));
8
+ }
9
+
10
+ async createCompanies() {
11
+ const companies: ICompany[] = [
12
+ { name: 'AssetCo' },
13
+ { name: 'OpCo' },
14
+ ];
15
+ await Promise.all(companies.map(async (company) => {
16
+ await Company.findOneAndUpdate(
17
+ { name: company.name },
18
+ { $setOnInsert: { name: company.name } },
19
+ { upsert: true, new: true },
20
+ );
21
+ }));
22
+ }
23
+ }
@@ -0,0 +1,152 @@
1
+ /// <reference types="mongoose/types/aggregate" />
2
+ /// <reference types="mongoose/types/callback" />
3
+ /// <reference types="mongoose/types/collection" />
4
+ /// <reference types="mongoose/types/connection" />
5
+ /// <reference types="mongoose/types/cursor" />
6
+ /// <reference types="mongoose/types/document" />
7
+ /// <reference types="mongoose/types/error" />
8
+ /// <reference types="mongoose/types/expressions" />
9
+ /// <reference types="mongoose/types/helpers" />
10
+ /// <reference types="mongoose/types/middlewares" />
11
+ /// <reference types="mongoose/types/indexes" />
12
+ /// <reference types="mongoose/types/models" />
13
+ /// <reference types="mongoose/types/mongooseoptions" />
14
+ /// <reference types="mongoose/types/pipelinestage" />
15
+ /// <reference types="mongoose/types/populate" />
16
+ /// <reference types="mongoose/types/query" />
17
+ /// <reference types="mongoose/types/schemaoptions" />
18
+ /// <reference types="mongoose/types/schematypes" />
19
+ /// <reference types="mongoose/types/session" />
20
+ /// <reference types="mongoose/types/types" />
21
+ /// <reference types="mongoose/types/utility" />
22
+ /// <reference types="mongoose/types/validation" />
23
+ /// <reference types="mongoose/types/virtuals" />
24
+ /// <reference types="mongoose/types/inferschematype" />
25
+ import mongoose from 'mongoose';
26
+ import { IEmailRecipient } from '../models/ComplianceItem.model';
27
+ import { IGroupedEmailsUpdate } from '../interfaces/email-addresses.interface';
28
+ import { IComplianceBorrowerDocument, IComplianceBorrowerDocumentFull } from '../models/BorrowerCompliance.model';
29
+ import { IUser } from '../models/User.model';
30
+ import { FileManagerService } from './file-manager.service';
31
+ import { UploadsService } from './uploads.service';
32
+ export declare class ComplianceBorrowersService {
33
+ private readonly _fileManagerService;
34
+ private readonly _uploadsService;
35
+ constructor(_fileManagerService: FileManagerService, _uploadsService: UploadsService);
36
+ isComplianceBorrowerAllowed(userAccess: any, requestedBorrowerId: any): boolean;
37
+ calculateInstanceStatuses(instance: any, item: any): {
38
+ progress: {
39
+ text: string;
40
+ status: string;
41
+ };
42
+ score: {
43
+ value: number;
44
+ tooltip: string;
45
+ };
46
+ };
47
+ getFullComplianceBorrowerById(complianceBorrowerId: any): Promise<any>;
48
+ getAllBorrowersShortened(userAccess: any): Promise<(Pick<IComplianceBorrowerDocument, "items" | "borrower" | "fundingStatus"> | {
49
+ items: {
50
+ instances: any[];
51
+ item: import("../models/ComplianceItem.model").IComplianceItemDocument;
52
+ startDate: Date;
53
+ frequency: string;
54
+ emailAddresses: import("../models/ComplianceItem.model").IEmailRecipientDocument[];
55
+ _id?: any;
56
+ __v?: any;
57
+ $locals: Record<string, unknown>;
58
+ $op: "save" | "validate" | "remove";
59
+ $where: Record<string, unknown>;
60
+ baseModelName?: string;
61
+ collection: mongoose.Collection<mongoose.mongo.BSON.Document>;
62
+ db: mongoose.Connection;
63
+ errors?: mongoose.Error.ValidationError;
64
+ id?: any;
65
+ isNew: boolean;
66
+ schema: mongoose.Schema<any, mongoose.Model<any, any, any, any, any, any>, {}, {}, {}, {}, mongoose.DefaultSchemaOptions, {
67
+ [x: string]: unknown;
68
+ }, mongoose.Document<unknown, {}, mongoose.FlatRecord<{
69
+ [x: string]: unknown;
70
+ }>> & mongoose.FlatRecord<{
71
+ [x: string]: unknown;
72
+ }> & Required<{
73
+ _id: unknown;
74
+ }>>;
75
+ }[];
76
+ borrower: any;
77
+ fundingStatus?: string;
78
+ })[]>;
79
+ generateInstances(complianceBorrowerId: any): Promise<any>;
80
+ calculateAndUpdateFundingStatus(complianceBorrowerId: string): Promise<void>;
81
+ calculateFundingStatus(complianceBorrower: IComplianceBorrowerDocumentFull): string;
82
+ updateComplianceBorrower(complianceBorrower: IComplianceBorrowerDocumentFull): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
83
+ _id: mongoose.Types.ObjectId;
84
+ }>;
85
+ updateFundingStatus(complianceBorrowerId: string, fundingStatus: string): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
86
+ _id: mongoose.Types.ObjectId;
87
+ }>;
88
+ updateLastEmailSent(complianceBorrowerId: string, lastEmailSentAt: Date): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
89
+ _id: mongoose.Types.ObjectId;
90
+ }>;
91
+ getAllBorrowersIds(onlyActive?: boolean): Promise<any[]>;
92
+ getBorrowerListByItemId(complianceItemId: string): Promise<Omit<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
93
+ _id: mongoose.Types.ObjectId;
94
+ }, never>[]>;
95
+ deleteInstanceById(complianceBorrowerId: string, complianceInstanceId: string): Promise<void>;
96
+ getBorrowerByInstanceId(complianceInstanceId: string): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
97
+ _id: mongoose.Types.ObjectId;
98
+ }>;
99
+ markInstanceFilesAsOld(complianceInstanceId: string): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
100
+ _id: mongoose.Types.ObjectId;
101
+ }>;
102
+ getBorrowerWithPlaidToken(): Promise<(mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
103
+ _id: mongoose.Types.ObjectId;
104
+ })[]>;
105
+ getBorrowerEmails(userAccess: any): Promise<{
106
+ borrower: {
107
+ _id: any;
108
+ name: any;
109
+ borrowerId: any;
110
+ };
111
+ email: string;
112
+ mainEmails: IEmailRecipient[];
113
+ financialEmails: IEmailRecipient[];
114
+ isEmailingActive: boolean;
115
+ isDailyTransactionsEmailingActive: boolean;
116
+ uniqEmails: any[];
117
+ groupedEmails: {};
118
+ items: {
119
+ value: any;
120
+ title: string;
121
+ }[];
122
+ }[]>;
123
+ getOneBorrowerEmails(userAccess: any, borrowerId: any): Promise<{
124
+ borrower: {
125
+ _id: any;
126
+ name: any;
127
+ borrowerId: any;
128
+ };
129
+ email: string;
130
+ mainEmails: IEmailRecipient[];
131
+ financialEmails: IEmailRecipient[];
132
+ isEmailingActive: boolean;
133
+ isDailyTransactionsEmailingActive: boolean;
134
+ uniqEmails: any[];
135
+ groupedEmails: {};
136
+ items: {
137
+ value: any;
138
+ title: string;
139
+ }[];
140
+ }>;
141
+ getBorrowerEmailsGrouped(borrowerId: string): Promise<{
142
+ mainEmails: IEmailRecipient[];
143
+ financialEmails: IEmailRecipient[];
144
+ }>;
145
+ updateBorrowerEmailAddresses(emailUpdate: IGroupedEmailsUpdate): Promise<mongoose.Document<unknown, {}, IComplianceBorrowerDocument> & IComplianceBorrowerDocument & {
146
+ _id: mongoose.Types.ObjectId;
147
+ }>;
148
+ toggleComplianceBorrowerVisibility(borrowerId: string, isVisible: boolean): Promise<void>;
149
+ createComplianceBorrower(borrowerId: string, isVisible?: boolean): Promise<void>;
150
+ removeIncorrectBorrowers(): Promise<void>;
151
+ getBorrowerListReport(user: IUser): Promise<any>;
152
+ }