payservedb 6.4.7 → 6.4.9

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 (139) hide show
  1. package/.env +2 -2
  2. package/index.js +275 -275
  3. package/package.json +17 -17
  4. package/src/models/account.js +35 -35
  5. package/src/models/apilog.js +18 -18
  6. package/src/models/approvalsWorkflows.js +49 -49
  7. package/src/models/archivedapilog.js +18 -18
  8. package/src/models/archivedauditlog.js +83 -83
  9. package/src/models/asset.js +67 -35
  10. package/src/models/assetsAssignment.js +64 -64
  11. package/src/models/auditlog.js +83 -83
  12. package/src/models/bankdetails.js +40 -40
  13. package/src/models/billerAddress.js +119 -119
  14. package/src/models/booking_invoice.js +151 -151
  15. package/src/models/bookinganalytics.js +63 -63
  16. package/src/models/bookingconfig.js +45 -45
  17. package/src/models/bookingproperty.js +122 -122
  18. package/src/models/bookingreservation.js +192 -192
  19. package/src/models/bookingrevenuerecord.js +84 -84
  20. package/src/models/budget.js +95 -95
  21. package/src/models/budgetCategory.js +19 -19
  22. package/src/models/campaigns.js +79 -73
  23. package/src/models/cashpayment.js +264 -264
  24. package/src/models/combinedUnits.js +62 -62
  25. package/src/models/common_area_electricity.js +38 -38
  26. package/src/models/common_area_generator.js +41 -41
  27. package/src/models/common_area_utility_alert.js +37 -37
  28. package/src/models/common_area_water.js +39 -39
  29. package/src/models/communication_status.js +33 -33
  30. package/src/models/company.js +53 -53
  31. package/src/models/country_tax.js +42 -42
  32. package/src/models/currency_settings.js +39 -39
  33. package/src/models/customer.js +208 -208
  34. package/src/models/default_payment_details.js +17 -17
  35. package/src/models/deliveryTimeMarks.js +18 -18
  36. package/src/models/{dutyRoasterChecklist.js → dutyRosterChecklist.js} +250 -250
  37. package/src/models/dutyroster.js +136 -136
  38. package/src/models/email.js +37 -37
  39. package/src/models/email_sms_queue.js +61 -61
  40. package/src/models/entry_exit.js +53 -53
  41. package/src/models/expense.js +99 -99
  42. package/src/models/expense_category.js +45 -45
  43. package/src/models/facility.js +61 -61
  44. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  45. package/src/models/facility_departements.js +20 -20
  46. package/src/models/facility_payment_details.js +20 -20
  47. package/src/models/facilityasset.js +25 -25
  48. package/src/models/faq.js +18 -18
  49. package/src/models/gl_account_double_entries.js +25 -25
  50. package/src/models/gl_accounts.js +56 -56
  51. package/src/models/gl_entries.js +49 -49
  52. package/src/models/goodsReceivedNotes.js +115 -115
  53. package/src/models/guard.js +47 -47
  54. package/src/models/handover.js +246 -246
  55. package/src/models/invoice.js +336 -336
  56. package/src/models/item_inspection.js +67 -67
  57. package/src/models/leaseagreement.js +252 -252
  58. package/src/models/leasetemplate.js +17 -17
  59. package/src/models/levy.js +206 -206
  60. package/src/models/levy_invoice_settings.js +26 -26
  61. package/src/models/levycontract.js +117 -117
  62. package/src/models/levytype.js +23 -23
  63. package/src/models/maintenance_service_vendor.js +38 -38
  64. package/src/models/maintenance_services.js +17 -17
  65. package/src/models/maintenancerequisition.js +31 -31
  66. package/src/models/master_workplan.js +32 -32
  67. package/src/models/master_workplan_child.js +34 -34
  68. package/src/models/message.js +38 -38
  69. package/src/models/module.js +21 -21
  70. package/src/models/notification.js +44 -44
  71. package/src/models/paymentTermsMarks.js +19 -19
  72. package/src/models/penalty.js +76 -76
  73. package/src/models/pendingCredentials.js +32 -32
  74. package/src/models/powerMeterCustomerAccount.js +78 -78
  75. package/src/models/powerMeterCustomerBand.js +14 -14
  76. package/src/models/powerMeterDailyReading.js +30 -30
  77. package/src/models/powerMeterMonthlyReading.js +34 -34
  78. package/src/models/powerMeterPowerCharges.js +53 -53
  79. package/src/models/powerMeterSettings.js +138 -138
  80. package/src/models/powerMeterSingleDayReading.js +32 -32
  81. package/src/models/powerMeters.js +65 -65
  82. package/src/models/powerMetersManufacturer.js +14 -14
  83. package/src/models/propertyManagerContract.js +556 -556
  84. package/src/models/propertyManagerRevenue.js +195 -195
  85. package/src/models/purchaseOrderInvoice.js +74 -74
  86. package/src/models/purchase_order.js +213 -213
  87. package/src/models/purchase_request.js +110 -110
  88. package/src/models/refresh_token.js +23 -23
  89. package/src/models/reminder.js +197 -197
  90. package/src/models/report.js +13 -13
  91. package/src/models/resident.js +121 -121
  92. package/src/models/rfq_details.js +131 -131
  93. package/src/models/rfq_response.js +153 -153
  94. package/src/models/service_charge_invoice_upload.js +42 -42
  95. package/src/models/service_charge_payments.js +27 -27
  96. package/src/models/servicerequest.js +55 -55
  97. package/src/models/settings.js +62 -62
  98. package/src/models/smart_meter_daily_consumption.js +44 -44
  99. package/src/models/sms_africastalking.js +20 -20
  100. package/src/models/sms_balance_notification.js +26 -26
  101. package/src/models/sms_meliora.js +20 -20
  102. package/src/models/staff.js +36 -36
  103. package/src/models/stocksandspare.js +34 -34
  104. package/src/models/suppliers.js +74 -74
  105. package/src/models/tickets.js +121 -121
  106. package/src/models/unitManagementTemplate.js +44 -44
  107. package/src/models/unitasset.js +25 -25
  108. package/src/models/units.js +117 -117
  109. package/src/models/user.js +186 -186
  110. package/src/models/valueaddedservices.js +79 -79
  111. package/src/models/vas_invoices_upload.js +50 -50
  112. package/src/models/vas_payments.js +24 -24
  113. package/src/models/vasinvoice.js +192 -192
  114. package/src/models/vasvendor.js +57 -57
  115. package/src/models/visitLog.js +86 -86
  116. package/src/models/visitor.js +67 -67
  117. package/src/models/waitlist.js +45 -45
  118. package/src/models/wallet.js +44 -44
  119. package/src/models/wallet_transactions.js +50 -50
  120. package/src/models/water_invoice.js +281 -281
  121. package/src/models/water_meter_Command_Queue.js +33 -33
  122. package/src/models/water_meter_account.js +78 -78
  123. package/src/models/water_meter_billing.js +58 -58
  124. package/src/models/water_meter_communication.js +17 -17
  125. package/src/models/water_meter_communication_logs.js +30 -30
  126. package/src/models/water_meter_concentrator.js +66 -66
  127. package/src/models/water_meter_daily_history.js +32 -32
  128. package/src/models/water_meter_iot_cards.js +34 -34
  129. package/src/models/water_meter_manufacturer.js +35 -35
  130. package/src/models/water_meter_monthly_history.js +36 -36
  131. package/src/models/water_meter_negative_amounts.js +38 -38
  132. package/src/models/water_meter_settings.js +156 -156
  133. package/src/models/water_meter_single_day_history.js +34 -34
  134. package/src/models/water_meter_size.js +15 -15
  135. package/src/models/water_meters.js +123 -123
  136. package/src/models/water_meters_delivery.js +76 -76
  137. package/src/models/water_prepaid_credit.js +47 -47
  138. package/src/models/water_prepaid_debit.js +50 -50
  139. package/src/models/workorder.js +49 -49
@@ -1,282 +1,282 @@
1
- const mongoose = require('mongoose');
2
-
3
- const waterInvoiceSchema = new mongoose.Schema(
4
- {
5
- // Basic identifiers
6
- invoiceNumber: {
7
- type: String,
8
- required: true,
9
- unique: true
10
- },
11
- accountNumber: {
12
- type: String,
13
- required: true
14
- },
15
- unitName: {
16
- type: String,
17
- required: true,
18
- },
19
- yearMonth: {
20
- type: String,
21
- required: true,
22
- },
23
- facilityId: {
24
- type: mongoose.Schema.Types.ObjectId,
25
- required: true
26
- },
27
- customerId: {
28
- type: mongoose.Schema.Types.ObjectId,
29
- required: true
30
- },
31
- billingType: {
32
- type: String,
33
- enum: ['postpaid'],
34
- },
35
- balanceBroughtForward: {
36
- type: Number,
37
- default: 0
38
- },
39
-
40
- // Biller Address Information (added from WaterMeterSettings)
41
- billerAddress: {
42
- name: {
43
- type: String,
44
- required: [true, "Biller name is required"],
45
- trim: true,
46
- minlength: [1, "Biller name must be at least 1 character long"],
47
- },
48
- email: {
49
- type: String,
50
- required: [true, "Biller email is required"],
51
- trim: true,
52
- lowercase: true,
53
- validate: {
54
- validator: function (v) {
55
- return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
56
- },
57
- message: "Please enter a valid email address"
58
- }
59
- },
60
- phone: {
61
- type: String,
62
- required: [true, "Biller phone is required"],
63
- trim: true,
64
- },
65
- address: {
66
- type: String,
67
- required: [true, "Biller address is required"],
68
- trim: true,
69
- },
70
- city: {
71
- type: String,
72
- required: [true, "Biller city is required"],
73
- trim: true,
74
- }
75
- },
76
-
77
- // Dates
78
- dateIssued: {
79
- type: Date,
80
- default: Date.now
81
- },
82
- dueDate: {
83
- type: Date,
84
- required: true
85
- },
86
-
87
- // Meter & Consumption Details
88
- meterNumber: {
89
- type: String,
90
- required: true
91
- },
92
- meterReadings: {
93
- previousReading: {
94
- type: Number,
95
- required: true
96
- },
97
- currentReading: {
98
- type: Number,
99
- required: true
100
- },
101
- usage: {
102
- type: Number,
103
- required: true,
104
- }
105
- },
106
- consumptionPeriod: {
107
- startDate: {
108
- type: Date,
109
- required: true
110
- },
111
- endDate: {
112
- type: Date,
113
- required: true
114
- }
115
- },
116
-
117
- // Charges
118
- charges: {
119
- waterCharge: {
120
- type: Number,
121
- required: true
122
- },
123
- sewerCharge: {
124
- type: Number,
125
- default: 0
126
- },
127
- tax: {
128
- type: Number,
129
- default: 0
130
- },
131
- fixedCharge: {
132
- type: Number,
133
- default: 0
134
- },
135
- totalMonthlyBill: {
136
- type: Number,
137
- required: true
138
- }
139
- },
140
- amountPaid: {
141
- type: Number,
142
- default: 0
143
- },
144
- imageUrl: { type: String, trim: true },
145
-
146
- // Invoice Note & Status
147
- invoiceNote: {
148
- type: String,
149
- default: 'Payment is due within 10 days'
150
- },
151
- status: {
152
- type: String,
153
- required: true,
154
- enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid'],
155
- default: 'Pending'
156
- },
157
-
158
- // Currency Info
159
- currency: {
160
- id: {
161
- type: mongoose.Schema.Types.ObjectId
162
- },
163
- name: {
164
- type: String,
165
- default: 'Kenyan Shilling'
166
- },
167
- code: {
168
- type: String,
169
- default: 'KES'
170
- },
171
- symbol: {
172
- type: String,
173
- default: 'KSh'
174
- }
175
- },
176
- notificationsSent: {
177
- type: {
178
- sms: {
179
- type: Boolean,
180
- default: false
181
- },
182
- email: {
183
- type: Boolean,
184
- default: false
185
- },
186
- sentAt: {
187
- type: Date,
188
- default: null
189
- },
190
- lastAttempt: {
191
- type: Date,
192
- default: null
193
- },
194
- attempts: {
195
- type: Number,
196
- default: 0
197
- },
198
- smsDetails: {
199
- type: {
200
- success: Boolean,
201
- error: String,
202
- sentAt: Date,
203
- phoneNumber: String
204
- },
205
- default: null
206
- },
207
- emailDetails: {
208
- type: {
209
- success: Boolean,
210
- error: String,
211
- sentAt: Date,
212
- emailAddress: String
213
- },
214
- default: null
215
- }
216
- },
217
- default: {
218
- sms: false,
219
- email: false,
220
- sentAt: null,
221
- lastAttempt: null,
222
- attempts: 0,
223
- smsDetails: null,
224
- emailDetails: null
225
- }
226
- },
227
-
228
- // Payment & Reconciliation
229
- reconciliationHistory: [
230
- {
231
- date: {
232
- type: Date,
233
- default: Date.now
234
- },
235
- amount: {
236
- type: Number,
237
- required: true
238
- },
239
- type: {
240
- type: String,
241
- default: 'Manual'
242
- },
243
- paymentReference: {
244
- type: String
245
- },
246
- paymentCompletion: {
247
- type: String,
248
- default: 'Completed'
249
- },
250
- sourceInvoice: {
251
- type: String
252
- },
253
- destinationInvoice: {
254
- type: String
255
- },
256
- notes: {
257
- type: String
258
- },
259
- remainingBalance: {
260
- type: Number
261
- }
262
- }
263
- ],
264
- },
265
- {
266
- timestamps: true
267
- }
268
- );
269
-
270
- waterInvoiceSchema.pre('save', function (next) {
271
- if (this.isModified('dueDate') || this.isNew) {
272
- const today = new Date();
273
- if (this.dueDate < today && this.status === 'Pending') {
274
- this.status = 'Overdue';
275
- }
276
- }
277
- next();
278
- });
279
-
280
- const WaterInvoice = mongoose.model('WaterInvoice', waterInvoiceSchema);
281
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const waterInvoiceSchema = new mongoose.Schema(
4
+ {
5
+ // Basic identifiers
6
+ invoiceNumber: {
7
+ type: String,
8
+ required: true,
9
+ unique: true
10
+ },
11
+ accountNumber: {
12
+ type: String,
13
+ required: true
14
+ },
15
+ unitName: {
16
+ type: String,
17
+ required: true,
18
+ },
19
+ yearMonth: {
20
+ type: String,
21
+ required: true,
22
+ },
23
+ facilityId: {
24
+ type: mongoose.Schema.Types.ObjectId,
25
+ required: true
26
+ },
27
+ customerId: {
28
+ type: mongoose.Schema.Types.ObjectId,
29
+ required: true
30
+ },
31
+ billingType: {
32
+ type: String,
33
+ enum: ['postpaid'],
34
+ },
35
+ balanceBroughtForward: {
36
+ type: Number,
37
+ default: 0
38
+ },
39
+
40
+ // Biller Address Information (added from WaterMeterSettings)
41
+ billerAddress: {
42
+ name: {
43
+ type: String,
44
+ required: [true, "Biller name is required"],
45
+ trim: true,
46
+ minlength: [1, "Biller name must be at least 1 character long"],
47
+ },
48
+ email: {
49
+ type: String,
50
+ required: [true, "Biller email is required"],
51
+ trim: true,
52
+ lowercase: true,
53
+ validate: {
54
+ validator: function (v) {
55
+ return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
56
+ },
57
+ message: "Please enter a valid email address"
58
+ }
59
+ },
60
+ phone: {
61
+ type: String,
62
+ required: [true, "Biller phone is required"],
63
+ trim: true,
64
+ },
65
+ address: {
66
+ type: String,
67
+ required: [true, "Biller address is required"],
68
+ trim: true,
69
+ },
70
+ city: {
71
+ type: String,
72
+ required: [true, "Biller city is required"],
73
+ trim: true,
74
+ }
75
+ },
76
+
77
+ // Dates
78
+ dateIssued: {
79
+ type: Date,
80
+ default: Date.now
81
+ },
82
+ dueDate: {
83
+ type: Date,
84
+ required: true
85
+ },
86
+
87
+ // Meter & Consumption Details
88
+ meterNumber: {
89
+ type: String,
90
+ required: true
91
+ },
92
+ meterReadings: {
93
+ previousReading: {
94
+ type: Number,
95
+ required: true
96
+ },
97
+ currentReading: {
98
+ type: Number,
99
+ required: true
100
+ },
101
+ usage: {
102
+ type: Number,
103
+ required: true,
104
+ }
105
+ },
106
+ consumptionPeriod: {
107
+ startDate: {
108
+ type: Date,
109
+ required: true
110
+ },
111
+ endDate: {
112
+ type: Date,
113
+ required: true
114
+ }
115
+ },
116
+
117
+ // Charges
118
+ charges: {
119
+ waterCharge: {
120
+ type: Number,
121
+ required: true
122
+ },
123
+ sewerCharge: {
124
+ type: Number,
125
+ default: 0
126
+ },
127
+ tax: {
128
+ type: Number,
129
+ default: 0
130
+ },
131
+ fixedCharge: {
132
+ type: Number,
133
+ default: 0
134
+ },
135
+ totalMonthlyBill: {
136
+ type: Number,
137
+ required: true
138
+ }
139
+ },
140
+ amountPaid: {
141
+ type: Number,
142
+ default: 0
143
+ },
144
+ imageUrl: { type: String, trim: true },
145
+
146
+ // Invoice Note & Status
147
+ invoiceNote: {
148
+ type: String,
149
+ default: 'Payment is due within 10 days'
150
+ },
151
+ status: {
152
+ type: String,
153
+ required: true,
154
+ enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid'],
155
+ default: 'Pending'
156
+ },
157
+
158
+ // Currency Info
159
+ currency: {
160
+ id: {
161
+ type: mongoose.Schema.Types.ObjectId
162
+ },
163
+ name: {
164
+ type: String,
165
+ default: 'Kenyan Shilling'
166
+ },
167
+ code: {
168
+ type: String,
169
+ default: 'KES'
170
+ },
171
+ symbol: {
172
+ type: String,
173
+ default: 'KSh'
174
+ }
175
+ },
176
+ notificationsSent: {
177
+ type: {
178
+ sms: {
179
+ type: Boolean,
180
+ default: false
181
+ },
182
+ email: {
183
+ type: Boolean,
184
+ default: false
185
+ },
186
+ sentAt: {
187
+ type: Date,
188
+ default: null
189
+ },
190
+ lastAttempt: {
191
+ type: Date,
192
+ default: null
193
+ },
194
+ attempts: {
195
+ type: Number,
196
+ default: 0
197
+ },
198
+ smsDetails: {
199
+ type: {
200
+ success: Boolean,
201
+ error: String,
202
+ sentAt: Date,
203
+ phoneNumber: String
204
+ },
205
+ default: null
206
+ },
207
+ emailDetails: {
208
+ type: {
209
+ success: Boolean,
210
+ error: String,
211
+ sentAt: Date,
212
+ emailAddress: String
213
+ },
214
+ default: null
215
+ }
216
+ },
217
+ default: {
218
+ sms: false,
219
+ email: false,
220
+ sentAt: null,
221
+ lastAttempt: null,
222
+ attempts: 0,
223
+ smsDetails: null,
224
+ emailDetails: null
225
+ }
226
+ },
227
+
228
+ // Payment & Reconciliation
229
+ reconciliationHistory: [
230
+ {
231
+ date: {
232
+ type: Date,
233
+ default: Date.now
234
+ },
235
+ amount: {
236
+ type: Number,
237
+ required: true
238
+ },
239
+ type: {
240
+ type: String,
241
+ default: 'Manual'
242
+ },
243
+ paymentReference: {
244
+ type: String
245
+ },
246
+ paymentCompletion: {
247
+ type: String,
248
+ default: 'Completed'
249
+ },
250
+ sourceInvoice: {
251
+ type: String
252
+ },
253
+ destinationInvoice: {
254
+ type: String
255
+ },
256
+ notes: {
257
+ type: String
258
+ },
259
+ remainingBalance: {
260
+ type: Number
261
+ }
262
+ }
263
+ ],
264
+ },
265
+ {
266
+ timestamps: true
267
+ }
268
+ );
269
+
270
+ waterInvoiceSchema.pre('save', function (next) {
271
+ if (this.isModified('dueDate') || this.isNew) {
272
+ const today = new Date();
273
+ if (this.dueDate < today && this.status === 'Pending') {
274
+ this.status = 'Overdue';
275
+ }
276
+ }
277
+ next();
278
+ });
279
+
280
+ const WaterInvoice = mongoose.model('WaterInvoice', waterInvoiceSchema);
281
+
282
282
  module.exports = WaterInvoice;
@@ -1,33 +1,33 @@
1
- const mongoose = require('mongoose');
2
-
3
- const meterCommandQueueSchema = new mongoose.Schema({
4
- meterNumber: {
5
- type: String,
6
- required: true
7
- },
8
- concentratorSerialNumber: {
9
- type: String,
10
- required: true
11
- },
12
- commandType: {
13
- type: String,
14
- enum: ['open', 'close', 'read'],
15
- required: true
16
- },
17
- status: {
18
- type: String,
19
- enum: ['pending', 'sent', 'acknowledged', 'failed'],
20
- default: 'pending'
21
- },
22
- retryCount: {
23
- type: Number,
24
- default: 0
25
- },
26
- sentAt: {
27
- type: Date
28
- }
29
- }, { timestamps: true });
30
-
31
- const MeterCommandQueue = mongoose.model('MeterCommandQueue', meterCommandQueueSchema);
32
-
33
- module.exports = MeterCommandQueue;
1
+ const mongoose = require('mongoose');
2
+
3
+ const meterCommandQueueSchema = new mongoose.Schema({
4
+ meterNumber: {
5
+ type: String,
6
+ required: true
7
+ },
8
+ concentratorSerialNumber: {
9
+ type: String,
10
+ required: true
11
+ },
12
+ commandType: {
13
+ type: String,
14
+ enum: ['open', 'close', 'read'],
15
+ required: true
16
+ },
17
+ status: {
18
+ type: String,
19
+ enum: ['pending', 'sent', 'acknowledged', 'failed'],
20
+ default: 'pending'
21
+ },
22
+ retryCount: {
23
+ type: Number,
24
+ default: 0
25
+ },
26
+ sentAt: {
27
+ type: Date
28
+ }
29
+ }, { timestamps: true });
30
+
31
+ const MeterCommandQueue = mongoose.model('MeterCommandQueue', meterCommandQueueSchema);
32
+
33
+ module.exports = MeterCommandQueue;