payservedb 5.2.3 → 5.2.5

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 (103) hide show
  1. package/.env +2 -2
  2. package/index.js +172 -172
  3. package/package.json +17 -17
  4. package/src/models/account.js +35 -35
  5. package/src/models/analog_water_billing.js +58 -58
  6. package/src/models/apilog.js +18 -18
  7. package/src/models/approvalsWorkflows.js +49 -49
  8. package/src/models/archivedapilog.js +18 -18
  9. package/src/models/archivedauditlog.js +83 -83
  10. package/src/models/asset.js +34 -34
  11. package/src/models/auditlog.js +83 -83
  12. package/src/models/bankdetails.js +40 -40
  13. package/src/models/bookinganalytics.js +63 -63
  14. package/src/models/bookingconfig.js +45 -45
  15. package/src/models/bookingproperty.js +112 -112
  16. package/src/models/bookingreservation.js +192 -192
  17. package/src/models/bookingrevenuerecord.js +84 -84
  18. package/src/models/budget.js +33 -33
  19. package/src/models/budgetCategory.js +19 -19
  20. package/src/models/campaigns.js +72 -72
  21. package/src/models/cashpayment.js +262 -262
  22. package/src/models/combinedUnits.js +62 -62
  23. package/src/models/common_area_electricity.js +38 -38
  24. package/src/models/common_area_generator.js +41 -41
  25. package/src/models/common_area_utility_alert.js +37 -37
  26. package/src/models/common_area_water.js +39 -39
  27. package/src/models/company.js +53 -53
  28. package/src/models/country_tax.js +42 -42
  29. package/src/models/currency_settings.js +39 -39
  30. package/src/models/customer.js +200 -200
  31. package/src/models/default_payment_details.js +17 -17
  32. package/src/models/dutyroster.js +107 -129
  33. package/src/models/email.js +24 -24
  34. package/src/models/entry_exit.js +53 -53
  35. package/src/models/expense.js +55 -55
  36. package/src/models/facility.js +61 -61
  37. package/src/models/facility_payment_details.js +20 -20
  38. package/src/models/facilityasset.js +25 -25
  39. package/src/models/faq.js +18 -18
  40. package/src/models/gl_account_double_entries.js +25 -25
  41. package/src/models/gl_accounts.js +56 -56
  42. package/src/models/gl_entries.js +49 -49
  43. package/src/models/guard.js +47 -47
  44. package/src/models/handover.js +241 -241
  45. package/src/models/invoice.js +336 -336
  46. package/src/models/item_inspection.js +67 -67
  47. package/src/models/leaseagreement.js +221 -221
  48. package/src/models/leasetemplate.js +17 -17
  49. package/src/models/levy.js +84 -84
  50. package/src/models/levy_invoice_settings.js +26 -26
  51. package/src/models/levycontract.js +158 -158
  52. package/src/models/levytype.js +23 -23
  53. package/src/models/maintenance_service_vendor.js +38 -38
  54. package/src/models/maintenance_services.js +17 -17
  55. package/src/models/maintenancerequisition.js +31 -31
  56. package/src/models/message.js +38 -38
  57. package/src/models/module.js +21 -21
  58. package/src/models/notification.js +24 -24
  59. package/src/models/penalty.js +76 -76
  60. package/src/models/purchase_order.js +190 -190
  61. package/src/models/purchase_request.js +65 -65
  62. package/src/models/refresh_token.js +23 -23
  63. package/src/models/reminder.js +197 -197
  64. package/src/models/report.js +13 -13
  65. package/src/models/resident.js +121 -121
  66. package/src/models/rfq_details.js +87 -87
  67. package/src/models/rfq_response.js +109 -109
  68. package/src/models/service_charge_invoice_upload.js +42 -42
  69. package/src/models/service_charge_payments.js +27 -27
  70. package/src/models/servicerequest.js +55 -55
  71. package/src/models/settings.js +62 -62
  72. package/src/models/smart_meter_daily_consumption.js +44 -44
  73. package/src/models/sms_africastalking.js +20 -20
  74. package/src/models/sms_meliora.js +16 -16
  75. package/src/models/staff.js +36 -36
  76. package/src/models/stocksandspare.js +34 -34
  77. package/src/models/suppliers.js +74 -74
  78. package/src/models/tickets.js +109 -109
  79. package/src/models/unitasset.js +25 -25
  80. package/src/models/units.js +94 -86
  81. package/src/models/user.js +187 -187
  82. package/src/models/valueaddedservices.js +36 -36
  83. package/src/models/vas_invoices_upload.js +50 -50
  84. package/src/models/vas_payments.js +24 -24
  85. package/src/models/vasinvoice.js +159 -159
  86. package/src/models/vasvendor.js +57 -57
  87. package/src/models/visitLog.js +86 -86
  88. package/src/models/visitor.js +67 -67
  89. package/src/models/waitlist.js +45 -45
  90. package/src/models/water_invoice.js +192 -192
  91. package/src/models/water_meter_account.js +73 -73
  92. package/src/models/water_meter_communication.js +17 -17
  93. package/src/models/water_meter_concentrator.js +59 -59
  94. package/src/models/water_meter_daily_history.js +31 -31
  95. package/src/models/water_meter_iot_cards.js +34 -34
  96. package/src/models/water_meter_manufacturer.js +35 -35
  97. package/src/models/water_meter_monthly_history.js +36 -36
  98. package/src/models/water_meter_settings.js +88 -88
  99. package/src/models/water_meter_single_day_history.js +29 -29
  100. package/src/models/water_meter_size.js +15 -15
  101. package/src/models/water_meters.js +106 -106
  102. package/src/models/water_meters_delivery.js +76 -76
  103. package/src/models/workorder.js +49 -49
package/.env CHANGED
@@ -1,3 +1,3 @@
1
- User=Ps
2
- Password=Letmein987
1
+ User=Ps
2
+ Password=Letmein987
3
3
  source=?authSource=admin
package/index.js CHANGED
@@ -1,173 +1,173 @@
1
- const mongoose = require('mongoose');
2
- require('dotenv').config()
3
-
4
-
5
- // Maintain a record of open connections for each database
6
- const connections = {};
7
-
8
-
9
- // Utility function to connect to MongoDB
10
- async function connectToMongoDB(dbName, secured, username, password, url, port) {
11
- try {
12
- if (secured === false) {
13
- const url_ = url + ":" + port;
14
- const connectionString = `mongodb://${url_}/${dbName}`;
15
- await mongoose.connect(connectionString, {
16
- useNewUrlParser: true,
17
- });
18
- console.log('Connected to MongoDB');
19
- }
20
- else {
21
- const url_ = `${username}:${password}@${url}:${port}`;
22
- const source = '?authSource=admin'
23
- const connectionString = `mongodb://${url_}/${dbName}${source}`;
24
- await mongoose.connect(connectionString, {
25
- useNewUrlParser: true,
26
- });
27
- console.log('Connected to MongoDB');
28
- }
29
-
30
- } catch (err) {
31
- console.error('Error connecting to MongoDB:', err);
32
- throw err;
33
- }
34
- }
35
-
36
-
37
- // Function to switch databases dynamically
38
- async function switchDB(dbName) {
39
- // Check if there's already a connection to the desired database
40
- if (connections[dbName]) {
41
- return connections[dbName]; // Return existing connection
42
- }
43
- try {
44
- const connectionString = `mongodb://${url}/${dbName}${source}`;
45
- const dbConnection = await mongoose.createConnection(connectionString, {
46
- useNewUrlParser: true,
47
- });
48
- connections[dbName] = dbConnection; // Store the connection for reuse
49
- console.log(`Switched to database: ${dbName}`);
50
- return dbConnection;
51
- } catch (err) {
52
- console.error(`Error switching to database: ${dbName}`, err);
53
- throw err;
54
- }
55
- }
56
-
57
-
58
- // Importing all model files (Note: models may need to be re-registered for different connections)
59
- const models = {
60
- User: require('./src/models/user'),
61
- AuditLog: require('./src/models/auditlog'),
62
- Company: require('./src/models/company'),
63
- Customer: require('./src/models/customer'),
64
- Email: require('./src/models/email'),
65
- Module: require('./src/models/module'),
66
- Facility: require('./src/models/facility'),
67
- RefreshToken: require('./src/models/refresh_token'),
68
- ApiLog: require('./src/models/apilog'),
69
- ArchivedApiLog: require('./src/models/archivedapilog'),
70
- ArchivedAuditLog: require('./src/models/archivedauditlog'),
71
- FacilityAsset: require('./src/models/facilityasset'),
72
- Unit: require('./src/models/units'),
73
- FAQ: require('./src/models/faq'),
74
- UnitAsset: require('./src/models/unitasset'),
75
- CombinedUnit: require('./src/models/combinedUnits'),
76
- Message: require('./src/models/message'),
77
- SMSAfricastalking: require('./src/models/sms_africastalking'),
78
- SMSMeliora: require('./src/models/sms_meliora'),
79
- EntryExit: require('./src/models/entry_exit'),
80
- Guard: require('./src/models/guard'),
81
- Visitor: require('./src/models/visitor'),
82
- VisitLog: require('./src/models/visitLog'),
83
- Settings: require('./src/models/settings'),
84
- Levy: require('./src/models/levy'),
85
- LevyType: require('./src/models/levytype'),
86
- LevyContract: require('./src/models/levycontract'),
87
- Invoice: require('./src/models/invoice'),
88
- Reminder: require('./src/models/reminder'),
89
- Penalty: require('./src/models/penalty'),
90
- Notifiaction: require('./src/models/notification'),
91
- Resident: require('./src/models/resident'),
92
- Asset: require('./src/models/asset'),
93
- DutyRoster: require('./src/models/dutyroster'),
94
- LeaseTemplate: require('./src/models/leasetemplate'),
95
- Report: require('./src/models/report'),
96
- Ticket: require('./src/models/tickets'),
97
- Stocksandspare: require('./src/models/stocksandspare'),
98
- ServiceVendor: require('./src/models/maintenance_service_vendor'),
99
- MaintenanceServices: require('./src/models/maintenance_services'),
100
- StockRequisition: require('./src/models/maintenancerequisition'),
101
- LeaseAgreement: require('./src/models/leaseagreement'),
102
- WorkOrder: require('./src/models/workorder'),
103
- ValueAddedService: require('./src/models/valueaddedservices'),
104
- VasInvoice: require('./src/models/vasinvoice'),
105
- VasVendor: require('./src/models/vasvendor'),
106
- Staff: require('./src/models/staff'),
107
- ServiceRequest: require('./src/models/servicerequest'),
108
- CountryTaxRate: require('./src/models/country_tax'),
109
- WaterMeter: require('./src/models/water_meters'),
110
- DailyConsumption: require('./src/models/smart_meter_daily_consumption'),
111
- WaterMeterSettings: require('./src/models/water_meter_settings'),
112
- AnalogBilling: require('./src/models/analog_water_billing'),
113
- MeterSize: require('./src/models/water_meter_size'),
114
- WaterInvoice: require('./src/models/water_invoice'),
115
- MeterProtocol: require('./src/models/water_meter_communication'),
116
- MeterManufacturer: require('./src/models/water_meter_manufacturer'),
117
- MeterIotCard: require('./src/models/water_meter_iot_cards'),
118
- MetersDelivery: require('./src/models/water_meters_delivery'),
119
- Concentrator: require('./src/models/water_meter_concentrator'),
120
- Handover: require('./src/models/handover'),
121
- Budget: require('./src/models/budget'),
122
- BudgetCategory: require('./src/models/budgetCategory'),
123
- Expense: require('./src/models/expense'),
124
- InvoiceSettings: require('./src/models/levy_invoice_settings'),
125
- Account: require('./src/models/account'),
126
- FacilityPaymentDetails: require('./src/models/facility_payment_details'),
127
- DefaultPaymentDetails: require('./src/models/default_payment_details'),
128
- Currency: require('./src/models/currency_settings'),
129
- WaterMeterAccount: require('./src/models/water_meter_account'),
130
- SingleDayWaterMeterHistory: require('./src/models/water_meter_single_day_history'),
131
- DailyWaterMeterHistory: require('./src/models/water_meter_daily_history'),
132
- MonthlyWaterMeterHistory: require('./src/models/water_meter_monthly_history'),
133
- CashPayment: require('./src/models/cashpayment'),
134
- VasPayment: require('./src/models/vas_payments'),
135
- VasInvoicesQuickBooks: require('./src/models/vas_invoices_upload'),
136
- ServiceChargePayment: require('./src/models/service_charge_payments'),
137
- ServiceChargeInvoiceUpload: require('./src/models/service_charge_invoice_upload'),
138
- Campaign: require('./src/models/campaigns'),
139
- InspectionItem: require('./src/models/item_inspection'),
140
- Supplier: require('./src/models/suppliers'),
141
- PurchaseRequest: require('./src/models/purchase_request'),
142
- PurchaseOrder: require('./src/models/purchase_order'),
143
- RFQDetails: require('./src/models/rfq_details'),
144
- RFQResponse: require('./src/models/rfq_response'),
145
- ApprovalWorkflow: require('./src/models/approvalsWorkflows'),
146
- CommonAreaElectricityReading: require('./src/models/common_area_electricity'),
147
- CommonAreaWaterReading: require('./src/models/common_area_water'),
148
- CommonAreaGeneratorReading: require('./src/models/common_area_generator'),
149
- CommonAreaUtilityAlert: require('./src/models/common_area_utility_alert'),
150
- BookingProperty: require('./src/models/bookingproperty'),
151
- BookingReservation: require('./src/models/bookingreservation'),
152
- BookingConfig: require('./src/models/bookingconfig'),
153
- BookingAnalytics: require('./src/models/bookinganalytics'),
154
- RevenueRecord: require('./src/models/bookingrevenuerecord'),
155
- GLAccount: require('./src/models/gl_accounts'),
156
- GLEntry: require('./src/models/gl_entries'),
157
- GLAccountDoubleEntries: require('./src/models/gl_account_double_entries'),
158
- };
159
-
160
- // Function to get models dynamically from a specific database connection
161
- async function getModelFromDB(dbConnection, modelName, schema) {
162
- if (!dbConnection.models[modelName]) {
163
- return dbConnection.model(modelName, schema); // Register the model in the db connection
164
- }
165
- return dbConnection.models[modelName]; // Return existing model if already registered
166
- }
167
-
168
- module.exports = {
169
- connectToMongoDB,
170
- switchDB,
171
- getModelFromDB,
172
- ...models // Spread operator to export all models
1
+ const mongoose = require('mongoose');
2
+ require('dotenv').config()
3
+
4
+
5
+ // Maintain a record of open connections for each database
6
+ const connections = {};
7
+
8
+
9
+ // Utility function to connect to MongoDB
10
+ async function connectToMongoDB(dbName, secured, username, password, url, port) {
11
+ try {
12
+ if (secured === false) {
13
+ const url_ = url + ":" + port;
14
+ const connectionString = `mongodb://${url_}/${dbName}`;
15
+ await mongoose.connect(connectionString, {
16
+ useNewUrlParser: true,
17
+ });
18
+ console.log('Connected to MongoDB');
19
+ }
20
+ else {
21
+ const url_ = `${username}:${password}@${url}:${port}`;
22
+ const source = '?authSource=admin'
23
+ const connectionString = `mongodb://${url_}/${dbName}${source}`;
24
+ await mongoose.connect(connectionString, {
25
+ useNewUrlParser: true,
26
+ });
27
+ console.log('Connected to MongoDB');
28
+ }
29
+
30
+ } catch (err) {
31
+ console.error('Error connecting to MongoDB:', err);
32
+ throw err;
33
+ }
34
+ }
35
+
36
+
37
+ // Function to switch databases dynamically
38
+ async function switchDB(dbName) {
39
+ // Check if there's already a connection to the desired database
40
+ if (connections[dbName]) {
41
+ return connections[dbName]; // Return existing connection
42
+ }
43
+ try {
44
+ const connectionString = `mongodb://${url}/${dbName}${source}`;
45
+ const dbConnection = await mongoose.createConnection(connectionString, {
46
+ useNewUrlParser: true,
47
+ });
48
+ connections[dbName] = dbConnection; // Store the connection for reuse
49
+ console.log(`Switched to database: ${dbName}`);
50
+ return dbConnection;
51
+ } catch (err) {
52
+ console.error(`Error switching to database: ${dbName}`, err);
53
+ throw err;
54
+ }
55
+ }
56
+
57
+
58
+ // Importing all model files (Note: models may need to be re-registered for different connections)
59
+ const models = {
60
+ User: require('./src/models/user'),
61
+ AuditLog: require('./src/models/auditlog'),
62
+ Company: require('./src/models/company'),
63
+ Customer: require('./src/models/customer'),
64
+ Email: require('./src/models/email'),
65
+ Module: require('./src/models/module'),
66
+ Facility: require('./src/models/facility'),
67
+ RefreshToken: require('./src/models/refresh_token'),
68
+ ApiLog: require('./src/models/apilog'),
69
+ ArchivedApiLog: require('./src/models/archivedapilog'),
70
+ ArchivedAuditLog: require('./src/models/archivedauditlog'),
71
+ FacilityAsset: require('./src/models/facilityasset'),
72
+ Unit: require('./src/models/units'),
73
+ FAQ: require('./src/models/faq'),
74
+ UnitAsset: require('./src/models/unitasset'),
75
+ CombinedUnit: require('./src/models/combinedUnits'),
76
+ Message: require('./src/models/message'),
77
+ SMSAfricastalking: require('./src/models/sms_africastalking'),
78
+ SMSMeliora: require('./src/models/sms_meliora'),
79
+ EntryExit: require('./src/models/entry_exit'),
80
+ Guard: require('./src/models/guard'),
81
+ Visitor: require('./src/models/visitor'),
82
+ VisitLog: require('./src/models/visitLog'),
83
+ Settings: require('./src/models/settings'),
84
+ Levy: require('./src/models/levy'),
85
+ LevyType: require('./src/models/levytype'),
86
+ LevyContract: require('./src/models/levycontract'),
87
+ Invoice: require('./src/models/invoice'),
88
+ Reminder: require('./src/models/reminder'),
89
+ Penalty: require('./src/models/penalty'),
90
+ Notifiaction: require('./src/models/notification'),
91
+ Resident: require('./src/models/resident'),
92
+ Asset: require('./src/models/asset'),
93
+ DutyRoster: require('./src/models/dutyroster'),
94
+ LeaseTemplate: require('./src/models/leasetemplate'),
95
+ Report: require('./src/models/report'),
96
+ Ticket: require('./src/models/tickets'),
97
+ Stocksandspare: require('./src/models/stocksandspare'),
98
+ ServiceVendor: require('./src/models/maintenance_service_vendor'),
99
+ MaintenanceServices: require('./src/models/maintenance_services'),
100
+ StockRequisition: require('./src/models/maintenancerequisition'),
101
+ LeaseAgreement: require('./src/models/leaseagreement'),
102
+ WorkOrder: require('./src/models/workorder'),
103
+ ValueAddedService: require('./src/models/valueaddedservices'),
104
+ VasInvoice: require('./src/models/vasinvoice'),
105
+ VasVendor: require('./src/models/vasvendor'),
106
+ Staff: require('./src/models/staff'),
107
+ ServiceRequest: require('./src/models/servicerequest'),
108
+ CountryTaxRate: require('./src/models/country_tax'),
109
+ WaterMeter: require('./src/models/water_meters'),
110
+ DailyConsumption: require('./src/models/smart_meter_daily_consumption'),
111
+ WaterMeterSettings: require('./src/models/water_meter_settings'),
112
+ AnalogBilling: require('./src/models/analog_water_billing'),
113
+ MeterSize: require('./src/models/water_meter_size'),
114
+ WaterInvoice: require('./src/models/water_invoice'),
115
+ MeterProtocol: require('./src/models/water_meter_communication'),
116
+ MeterManufacturer: require('./src/models/water_meter_manufacturer'),
117
+ MeterIotCard: require('./src/models/water_meter_iot_cards'),
118
+ MetersDelivery: require('./src/models/water_meters_delivery'),
119
+ Concentrator: require('./src/models/water_meter_concentrator'),
120
+ Handover: require('./src/models/handover'),
121
+ Budget: require('./src/models/budget'),
122
+ BudgetCategory: require('./src/models/budgetCategory'),
123
+ Expense: require('./src/models/expense'),
124
+ InvoiceSettings: require('./src/models/levy_invoice_settings'),
125
+ Account: require('./src/models/account'),
126
+ FacilityPaymentDetails: require('./src/models/facility_payment_details'),
127
+ DefaultPaymentDetails: require('./src/models/default_payment_details'),
128
+ Currency: require('./src/models/currency_settings'),
129
+ WaterMeterAccount: require('./src/models/water_meter_account'),
130
+ SingleDayWaterMeterHistory: require('./src/models/water_meter_single_day_history'),
131
+ DailyWaterMeterHistory: require('./src/models/water_meter_daily_history'),
132
+ MonthlyWaterMeterHistory: require('./src/models/water_meter_monthly_history'),
133
+ CashPayment: require('./src/models/cashpayment'),
134
+ VasPayment: require('./src/models/vas_payments'),
135
+ VasInvoicesQuickBooks: require('./src/models/vas_invoices_upload'),
136
+ ServiceChargePayment: require('./src/models/service_charge_payments'),
137
+ ServiceChargeInvoiceUpload: require('./src/models/service_charge_invoice_upload'),
138
+ Campaign: require('./src/models/campaigns'),
139
+ InspectionItem: require('./src/models/item_inspection'),
140
+ Supplier: require('./src/models/suppliers'),
141
+ PurchaseRequest: require('./src/models/purchase_request'),
142
+ PurchaseOrder: require('./src/models/purchase_order'),
143
+ RFQDetails: require('./src/models/rfq_details'),
144
+ RFQResponse: require('./src/models/rfq_response'),
145
+ ApprovalWorkflow: require('./src/models/approvalsWorkflows'),
146
+ CommonAreaElectricityReading: require('./src/models/common_area_electricity'),
147
+ CommonAreaWaterReading: require('./src/models/common_area_water'),
148
+ CommonAreaGeneratorReading: require('./src/models/common_area_generator'),
149
+ CommonAreaUtilityAlert: require('./src/models/common_area_utility_alert'),
150
+ BookingProperty: require('./src/models/bookingproperty'),
151
+ BookingReservation: require('./src/models/bookingreservation'),
152
+ BookingConfig: require('./src/models/bookingconfig'),
153
+ BookingAnalytics: require('./src/models/bookinganalytics'),
154
+ RevenueRecord: require('./src/models/bookingrevenuerecord'),
155
+ GLAccount: require('./src/models/gl_accounts'),
156
+ GLEntry: require('./src/models/gl_entries'),
157
+ GLAccountDoubleEntries: require('./src/models/gl_account_double_entries'),
158
+ };
159
+
160
+ // Function to get models dynamically from a specific database connection
161
+ async function getModelFromDB(dbConnection, modelName, schema) {
162
+ if (!dbConnection.models[modelName]) {
163
+ return dbConnection.model(modelName, schema); // Register the model in the db connection
164
+ }
165
+ return dbConnection.models[modelName]; // Return existing model if already registered
166
+ }
167
+
168
+ module.exports = {
169
+ connectToMongoDB,
170
+ switchDB,
171
+ getModelFromDB,
172
+ ...models // Spread operator to export all models
173
173
  }
package/package.json CHANGED
@@ -1,17 +1,17 @@
1
- {
2
- "name": "payservedb",
3
- "version": "5.2.3",
4
- "main": "index.js",
5
- "scripts": {
6
- "test": "echo \"Error: no test specified\" && exit 1"
7
- },
8
- "keywords": [],
9
- "author": "",
10
- "license": "ISC",
11
- "description": "",
12
- "dependencies": {
13
- "dotenv": "^16.4.5",
14
- "moment-timezone": "^0.5.47",
15
- "mongoose": "^8.3.5"
16
- }
17
- }
1
+ {
2
+ "name": "payservedb",
3
+ "version": "5.2.5",
4
+ "main": "index.js",
5
+ "scripts": {
6
+ "test": "echo \"Error: no test specified\" && exit 1"
7
+ },
8
+ "keywords": [],
9
+ "author": "",
10
+ "license": "ISC",
11
+ "description": "",
12
+ "dependencies": {
13
+ "dotenv": "^16.4.5",
14
+ "moment-timezone": "^0.5.47",
15
+ "mongoose": "^8.3.5"
16
+ }
17
+ }
@@ -1,36 +1,36 @@
1
- const mongoose = require("mongoose");
2
-
3
- const accountSchema = new mongoose.Schema({
4
- accountNumber: {
5
- type: String,
6
- required: true,
7
- unique: true,
8
- trim: true,
9
- },
10
- facilityId: {
11
- type: mongoose.Schema.Types.ObjectId,
12
- default: null,
13
- },
14
- customerId: {
15
- type: mongoose.Schema.Types.ObjectId,
16
- default: null,
17
- },
18
- isActive: {
19
- type: Boolean,
20
- default: true,
21
- },
22
- accountType: {
23
- type: String,
24
- },
25
- amount: {
26
- type: Number,
27
- },
28
- createdAt: {
29
- type: Date,
30
- default: Date.now,
31
- },
32
- });
33
-
34
- const Account = mongoose.model('Account', accountSchema);
35
-
1
+ const mongoose = require("mongoose");
2
+
3
+ const accountSchema = new mongoose.Schema({
4
+ accountNumber: {
5
+ type: String,
6
+ required: true,
7
+ unique: true,
8
+ trim: true,
9
+ },
10
+ facilityId: {
11
+ type: mongoose.Schema.Types.ObjectId,
12
+ default: null,
13
+ },
14
+ customerId: {
15
+ type: mongoose.Schema.Types.ObjectId,
16
+ default: null,
17
+ },
18
+ isActive: {
19
+ type: Boolean,
20
+ default: true,
21
+ },
22
+ accountType: {
23
+ type: String,
24
+ },
25
+ amount: {
26
+ type: Number,
27
+ },
28
+ createdAt: {
29
+ type: Date,
30
+ default: Date.now,
31
+ },
32
+ });
33
+
34
+ const Account = mongoose.model('Account', accountSchema);
35
+
36
36
  module.exports = Account;
@@ -1,58 +1,58 @@
1
- const mongoose = require('mongoose');
2
-
3
- const analogBillingSchema = new mongoose.Schema({
4
- facilityId: {
5
- type: mongoose.Schema.Types.ObjectId,
6
- ref: 'Facility',
7
- required: true,
8
- },
9
- meterNumber: {
10
- type: String,
11
- required: true,
12
- },
13
- accountNumber: {
14
- type: String,
15
- required: true,
16
- },
17
- currentReading: {
18
- type: Number,
19
- required: true,
20
- },
21
- previousReading: {
22
- type: Number,
23
- required: true,
24
- },
25
- yearMonth: {
26
- type: String, // Expected format: 'YYYY-MM'
27
- required: true,
28
- },
29
- totalUsage: {
30
- type: Number,
31
- required: true,
32
- },
33
- unitName: {
34
- type: String,
35
- required: true,
36
- },
37
- customerId: {
38
- type: mongoose.Schema.Types.ObjectId,
39
- ref: 'Customer',
40
- },
41
- billingType: {
42
- type: String,
43
- enum: ['postpaid', 'prepaid'],
44
- },
45
- status: {
46
- type: String,
47
- enum: ['pending', 'reviewed', 'billed'],
48
- default: 'pending',
49
- },
50
- }, {
51
- timestamps: true,
52
- });
53
-
54
- analogBillingSchema.index({ meterNumber: 1, yearMonth: 1 }, { unique: true });
55
-
56
- const AnalogBilling = mongoose.model('AnalogBilling', analogBillingSchema);
57
-
58
- module.exports = AnalogBilling;
1
+ const mongoose = require('mongoose');
2
+
3
+ const analogBillingSchema = new mongoose.Schema({
4
+ facilityId: {
5
+ type: mongoose.Schema.Types.ObjectId,
6
+ ref: 'Facility',
7
+ required: true,
8
+ },
9
+ meterNumber: {
10
+ type: String,
11
+ required: true,
12
+ },
13
+ accountNumber: {
14
+ type: String,
15
+ required: true,
16
+ },
17
+ currentReading: {
18
+ type: Number,
19
+ required: true,
20
+ },
21
+ previousReading: {
22
+ type: Number,
23
+ required: true,
24
+ },
25
+ yearMonth: {
26
+ type: String, // Expected format: 'YYYY-MM'
27
+ required: true,
28
+ },
29
+ totalUsage: {
30
+ type: Number,
31
+ required: true,
32
+ },
33
+ unitName: {
34
+ type: String,
35
+ required: true,
36
+ },
37
+ customerId: {
38
+ type: mongoose.Schema.Types.ObjectId,
39
+ ref: 'Customer',
40
+ },
41
+ billingType: {
42
+ type: String,
43
+ enum: ['postpaid', 'prepaid'],
44
+ },
45
+ status: {
46
+ type: String,
47
+ enum: ['pending', 'reviewed', 'billed'],
48
+ default: 'pending',
49
+ },
50
+ }, {
51
+ timestamps: true,
52
+ });
53
+
54
+ analogBillingSchema.index({ meterNumber: 1, yearMonth: 1 }, { unique: true });
55
+
56
+ const AnalogBilling = mongoose.model('AnalogBilling', analogBillingSchema);
57
+
58
+ module.exports = AnalogBilling;
@@ -1,18 +1,18 @@
1
- // models/apiLog.js
2
- const mongoose = require('mongoose');
3
- const { Schema } = mongoose;
4
-
5
- const apiLogSchema = new Schema({
6
- url: { type: String, required: true, index: true },
7
- method: { type: String, required: true, index: true },
8
- duration: { type: Number, required: true },
9
- time: { type: Date, default: Date.now, required: true, index: true },
10
- date: { type: String, required: true, index: true },
11
- });
12
-
13
-
14
- apiLogSchema.index({ time: 1 }, { expireAfterSeconds: 60 * 60 * 24 * 365 });
15
-
16
- const ApiLog = mongoose.model('ApiLog', apiLogSchema);
17
-
18
- module.exports = ApiLog;
1
+ // models/apiLog.js
2
+ const mongoose = require('mongoose');
3
+ const { Schema } = mongoose;
4
+
5
+ const apiLogSchema = new Schema({
6
+ url: { type: String, required: true, index: true },
7
+ method: { type: String, required: true, index: true },
8
+ duration: { type: Number, required: true },
9
+ time: { type: Date, default: Date.now, required: true, index: true },
10
+ date: { type: String, required: true, index: true },
11
+ });
12
+
13
+
14
+ apiLogSchema.index({ time: 1 }, { expireAfterSeconds: 60 * 60 * 24 * 365 });
15
+
16
+ const ApiLog = mongoose.model('ApiLog', apiLogSchema);
17
+
18
+ module.exports = ApiLog;