payservedb 4.9.2 → 4.9.4

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 (102) hide show
  1. package/.env +2 -2
  2. package/index.js +171 -171
  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 +38 -38
  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 +129 -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_accounts.js +56 -52
  41. package/src/models/gl_entries.js +50 -54
  42. package/src/models/guard.js +47 -47
  43. package/src/models/handover.js +241 -241
  44. package/src/models/invoice.js +291 -276
  45. package/src/models/item_inspection.js +67 -67
  46. package/src/models/leaseagreement.js +168 -168
  47. package/src/models/leasetemplate.js +17 -17
  48. package/src/models/levy.js +84 -84
  49. package/src/models/levy_invoice_settings.js +26 -26
  50. package/src/models/levycontract.js +77 -77
  51. package/src/models/levytype.js +23 -23
  52. package/src/models/maintenance_service_vendor.js +38 -38
  53. package/src/models/maintenance_services.js +17 -17
  54. package/src/models/maintenancerequisition.js +31 -31
  55. package/src/models/message.js +38 -38
  56. package/src/models/module.js +21 -21
  57. package/src/models/notification.js +24 -24
  58. package/src/models/penalty.js +76 -76
  59. package/src/models/purchase_order.js +190 -190
  60. package/src/models/purchase_request.js +65 -65
  61. package/src/models/refresh_token.js +23 -23
  62. package/src/models/reminder.js +161 -161
  63. package/src/models/report.js +13 -13
  64. package/src/models/resident.js +121 -121
  65. package/src/models/rfq_details.js +87 -87
  66. package/src/models/rfq_response.js +109 -109
  67. package/src/models/service_charge_invoice_upload.js +42 -42
  68. package/src/models/service_charge_payments.js +27 -27
  69. package/src/models/servicerequest.js +55 -55
  70. package/src/models/settings.js +62 -62
  71. package/src/models/smart_meter_daily_consumption.js +44 -44
  72. package/src/models/sms_africastalking.js +20 -20
  73. package/src/models/sms_meliora.js +16 -16
  74. package/src/models/staff.js +36 -36
  75. package/src/models/stocksandspare.js +34 -34
  76. package/src/models/suppliers.js +68 -68
  77. package/src/models/tickets.js +109 -109
  78. package/src/models/unitasset.js +25 -25
  79. package/src/models/units.js +86 -86
  80. package/src/models/user.js +183 -183
  81. package/src/models/valueaddedservices.js +36 -36
  82. package/src/models/vas_invoices_upload.js +50 -50
  83. package/src/models/vas_payments.js +24 -24
  84. package/src/models/vasinvoice.js +159 -159
  85. package/src/models/vasvendor.js +57 -57
  86. package/src/models/visitLog.js +86 -86
  87. package/src/models/visitor.js +63 -63
  88. package/src/models/waitlist.js +45 -45
  89. package/src/models/water_invoice.js +192 -192
  90. package/src/models/water_meter_account.js +74 -74
  91. package/src/models/water_meter_communication.js +17 -17
  92. package/src/models/water_meter_concentrator.js +59 -59
  93. package/src/models/water_meter_daily_history.js +31 -31
  94. package/src/models/water_meter_iot_cards.js +34 -34
  95. package/src/models/water_meter_manufacturer.js +35 -35
  96. package/src/models/water_meter_monthly_history.js +37 -37
  97. package/src/models/water_meter_settings.js +88 -88
  98. package/src/models/water_meter_single_day_history.js +31 -31
  99. package/src/models/water_meter_size.js +15 -15
  100. package/src/models/water_meters.js +103 -103
  101. package/src/models/water_meters_delivery.js +76 -76
  102. 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,172 +1,172 @@
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
- GLEntries: require('./src/models/gl_entries'),
157
- };
158
-
159
- // Function to get models dynamically from a specific database connection
160
- async function getModelFromDB(dbConnection, modelName, schema) {
161
- if (!dbConnection.models[modelName]) {
162
- return dbConnection.model(modelName, schema); // Register the model in the db connection
163
- }
164
- return dbConnection.models[modelName]; // Return existing model if already registered
165
- }
166
-
167
- module.exports = {
168
- connectToMongoDB,
169
- switchDB,
170
- getModelFromDB,
171
- ...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
+ GLEntries: require('./src/models/gl_entries'),
157
+ };
158
+
159
+ // Function to get models dynamically from a specific database connection
160
+ async function getModelFromDB(dbConnection, modelName, schema) {
161
+ if (!dbConnection.models[modelName]) {
162
+ return dbConnection.model(modelName, schema); // Register the model in the db connection
163
+ }
164
+ return dbConnection.models[modelName]; // Return existing model if already registered
165
+ }
166
+
167
+ module.exports = {
168
+ connectToMongoDB,
169
+ switchDB,
170
+ getModelFromDB,
171
+ ...models // Spread operator to export all models
172
172
  }
package/package.json CHANGED
@@ -1,17 +1,17 @@
1
- {
2
- "name": "payservedb",
3
- "version": "4.9.2",
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": "4.9.4",
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;