payservedb 8.4.6 → 8.4.8

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 (180) hide show
  1. package/.env +2 -2
  2. package/ZOHO_INTEGRATION_SCHEMA.md +644 -644
  3. package/index.js +312 -312
  4. package/package.json +17 -17
  5. package/src/models/account.js +52 -52
  6. package/src/models/agent_departments.js +59 -59
  7. package/src/models/agent_notifications.js +53 -53
  8. package/src/models/agent_performance.js +127 -127
  9. package/src/models/agent_roles.js +77 -77
  10. package/src/models/agents.js +154 -154
  11. package/src/models/apilog.js +18 -18
  12. package/src/models/approvalsWorkflows.js +49 -49
  13. package/src/models/archivedapilog.js +18 -18
  14. package/src/models/asset.js +92 -92
  15. package/src/models/assetsAssignment.js +64 -64
  16. package/src/models/auditTrail.js +346 -346
  17. package/src/models/bankdetails.js +47 -47
  18. package/src/models/billerAddress.js +124 -124
  19. package/src/models/booking_invoice.js +165 -165
  20. package/src/models/bookinganalytics.js +63 -63
  21. package/src/models/bookingconfig.js +45 -45
  22. package/src/models/bookingproperty.js +173 -173
  23. package/src/models/bookingreservation.js +209 -209
  24. package/src/models/bookingrevenuerecord.js +84 -84
  25. package/src/models/budget.js +95 -95
  26. package/src/models/budgetCategory.js +19 -19
  27. package/src/models/campaigns.js +108 -108
  28. package/src/models/cashpayment.js +264 -264
  29. package/src/models/combinedUnits.js +62 -62
  30. package/src/models/common_area_electricity.js +38 -38
  31. package/src/models/common_area_generator.js +41 -41
  32. package/src/models/common_area_utility_alert.js +37 -37
  33. package/src/models/common_area_water.js +39 -39
  34. package/src/models/communication_status.js +33 -33
  35. package/src/models/communication_user_opt.js +32 -32
  36. package/src/models/community_guidelines.js +31 -24
  37. package/src/models/company.js +53 -53
  38. package/src/models/coreBaseSettings.js +16 -16
  39. package/src/models/coreInvoiceSettings.js +100 -100
  40. package/src/models/counter_schema.js +21 -21
  41. package/src/models/country_tax.js +42 -42
  42. package/src/models/currency_settings.js +39 -39
  43. package/src/models/customer.js +210 -210
  44. package/src/models/customer_satisfaction_survey.js +278 -278
  45. package/src/models/customer_surveys.js +139 -139
  46. package/src/models/customer_tickets.js +239 -239
  47. package/src/models/dailyChecklist.js +312 -312
  48. package/src/models/default_payment_details.js +17 -17
  49. package/src/models/deliveryTimeMarks.js +18 -18
  50. package/src/models/document_type.js +19 -19
  51. package/src/models/dutyRosterChecklist.js +250 -250
  52. package/src/models/dutyroster.js +136 -136
  53. package/src/models/email.js +37 -37
  54. package/src/models/email_sms_queue.js +61 -61
  55. package/src/models/entry_exit.js +53 -53
  56. package/src/models/expense.js +99 -99
  57. package/src/models/expense_category.js +45 -45
  58. package/src/models/facility.js +71 -71
  59. package/src/models/facilityBillingPrices.js +29 -29
  60. package/src/models/facilityInvoice.js +240 -240
  61. package/src/models/facilityInvoicePayment.js +52 -52
  62. package/src/models/facilityInvoiceRecipient.js +32 -32
  63. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  64. package/src/models/facility_departements.js +20 -20
  65. package/src/models/facility_payment_details.js +20 -20
  66. package/src/models/facilityasset.js +25 -25
  67. package/src/models/faq.js +14 -14
  68. package/src/models/gl_account_double_entries.js +25 -25
  69. package/src/models/gl_accounts.js +56 -56
  70. package/src/models/gl_entries.js +49 -49
  71. package/src/models/goodsReceivedNotes.js +115 -115
  72. package/src/models/guard.js +47 -47
  73. package/src/models/handover.js +247 -247
  74. package/src/models/inspection_category.js +38 -38
  75. package/src/models/invoice.js +480 -480
  76. package/src/models/invoicing_schedule.js +41 -36
  77. package/src/models/item_inspection.js +96 -96
  78. package/src/models/knowledge_base.js +109 -109
  79. package/src/models/knowledge_base_rating.js +44 -44
  80. package/src/models/leaseagreement.js +236 -236
  81. package/src/models/leasetemplate.js +17 -17
  82. package/src/models/levy.js +223 -223
  83. package/src/models/levy_invoice_settings.js +26 -26
  84. package/src/models/levycontract.js +177 -177
  85. package/src/models/levytype.js +23 -23
  86. package/src/models/maintenance_service_vendor.js +38 -38
  87. package/src/models/maintenance_services.js +17 -17
  88. package/src/models/maintenancerequisition.js +31 -31
  89. package/src/models/master_workplan.js +32 -32
  90. package/src/models/master_workplan_child.js +34 -34
  91. package/src/models/message.js +38 -38
  92. package/src/models/module.js +21 -21
  93. package/src/models/notification.js +44 -44
  94. package/src/models/paymentTermsMarks.js +19 -19
  95. package/src/models/penalty.js +76 -76
  96. package/src/models/pendingCredentials.js +32 -32
  97. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  98. package/src/models/powerMeterCustomerAccount.js +78 -78
  99. package/src/models/powerMeterCustomerBand.js +14 -14
  100. package/src/models/powerMeterDailyReading.js +30 -30
  101. package/src/models/powerMeterGateways.js +40 -40
  102. package/src/models/powerMeterMonthlyReading.js +34 -34
  103. package/src/models/powerMeterPowerCharges.js +85 -85
  104. package/src/models/powerMeterSettings.js +159 -159
  105. package/src/models/powerMeterSingleDayReading.js +32 -32
  106. package/src/models/powerMeters.js +116 -116
  107. package/src/models/powerMetersManufacturer.js +14 -14
  108. package/src/models/power_meter_account.js +81 -81
  109. package/src/models/power_meter_command_logs.js +30 -30
  110. package/src/models/power_meter_command_queue.js +33 -33
  111. package/src/models/power_meter_negative_balance.js +44 -44
  112. package/src/models/power_prepaid_credits.js +47 -47
  113. package/src/models/power_prepaid_debits.js +53 -53
  114. package/src/models/power_prepaid_orders.js +78 -78
  115. package/src/models/power_sms_notification.js +26 -26
  116. package/src/models/privacy_policy.js +19 -19
  117. package/src/models/propertyManagerContract.js +556 -556
  118. package/src/models/propertyManagerRevenue.js +195 -195
  119. package/src/models/purchaseOrderInvoice.js +74 -74
  120. package/src/models/purchase_order.js +213 -213
  121. package/src/models/purchase_request.js +110 -110
  122. package/src/models/refresh_token.js +23 -23
  123. package/src/models/reminder.js +197 -197
  124. package/src/models/report.js +13 -13
  125. package/src/models/resident.js +121 -121
  126. package/src/models/rfq_details.js +131 -131
  127. package/src/models/rfq_response.js +153 -153
  128. package/src/models/service_charge_invoice_upload.js +42 -42
  129. package/src/models/service_charge_payments.js +27 -27
  130. package/src/models/servicerequest.js +55 -55
  131. package/src/models/settings.js +62 -62
  132. package/src/models/short_urls.js +21 -21
  133. package/src/models/smart_meter_daily_consumption.js +44 -44
  134. package/src/models/sms_africastalking.js +20 -20
  135. package/src/models/sms_balance_notification.js +26 -26
  136. package/src/models/sms_meliora.js +20 -20
  137. package/src/models/staff.js +36 -36
  138. package/src/models/stocksandspare.js +161 -161
  139. package/src/models/suppliers.js +74 -74
  140. package/src/models/terms_and_conditions.js +19 -19
  141. package/src/models/tickets.js +186 -186
  142. package/src/models/tickets_category.js +72 -72
  143. package/src/models/unitManagementTemplate.js +44 -44
  144. package/src/models/unitasset.js +25 -25
  145. package/src/models/units.js +118 -118
  146. package/src/models/user.js +186 -186
  147. package/src/models/valueaddedservices.js +79 -79
  148. package/src/models/vas_invoices_upload.js +50 -50
  149. package/src/models/vas_payments.js +24 -24
  150. package/src/models/vasinvoice.js +192 -192
  151. package/src/models/vasvendor.js +57 -57
  152. package/src/models/visitLog.js +95 -95
  153. package/src/models/visitor.js +67 -67
  154. package/src/models/waitlist.js +45 -45
  155. package/src/models/wallet.js +44 -44
  156. package/src/models/wallet_transactions.js +50 -50
  157. package/src/models/water_invoice.js +351 -351
  158. package/src/models/water_meter_Command_Queue.js +33 -33
  159. package/src/models/water_meter_account.js +87 -87
  160. package/src/models/water_meter_billing.js +58 -58
  161. package/src/models/water_meter_communication.js +17 -17
  162. package/src/models/water_meter_communication_logs.js +39 -39
  163. package/src/models/water_meter_concentrator.js +70 -70
  164. package/src/models/water_meter_daily_history.js +32 -32
  165. package/src/models/water_meter_high_risk.js +36 -36
  166. package/src/models/water_meter_iot_cards.js +34 -34
  167. package/src/models/water_meter_manufacturer.js +35 -35
  168. package/src/models/water_meter_monthly_history.js +36 -36
  169. package/src/models/water_meter_negative_amounts.js +44 -44
  170. package/src/models/water_meter_settings.js +287 -287
  171. package/src/models/water_meter_single_day_history.js +34 -34
  172. package/src/models/water_meter_size.js +15 -15
  173. package/src/models/water_meters.js +133 -133
  174. package/src/models/water_meters_delivery.js +76 -76
  175. package/src/models/water_prepaid_credit.js +47 -47
  176. package/src/models/water_prepaid_debit.js +50 -50
  177. package/src/models/workorder.js +49 -49
  178. package/src/models/zohoAccount.js +453 -453
  179. package/src/models/zohoIntegration.js +262 -262
  180. package/src/models/zohoItem.js +504 -504
@@ -1,239 +1,239 @@
1
- const mongoose = require('mongoose');
2
-
3
- const customerTicketSchema = new mongoose.Schema({
4
- ticket_number: {
5
- type: String,
6
- required: true,
7
- unique: true,
8
- trim: true
9
- },
10
- facility_id: {
11
- type: mongoose.Schema.Types.ObjectId,
12
- ref: 'Facility',
13
- required: true
14
- },
15
- customer_id: {
16
- type: mongoose.Schema.Types.ObjectId,
17
- ref: 'Customer',
18
- required: true
19
- },
20
- unit_id: {
21
- type: mongoose.Schema.Types.ObjectId,
22
- ref: 'Unit'
23
- },
24
- assigned_agent_id: {
25
- type: mongoose.Schema.Types.ObjectId,
26
- ref: 'User'
27
- },
28
- created_by_agent_id: {
29
- type: mongoose.Schema.Types.ObjectId,
30
- ref: 'User',
31
- required: true
32
- },
33
- title: {
34
- type: String,
35
- required: true,
36
- trim: true,
37
- maxlength: 255
38
- },
39
- description: {
40
- type: String,
41
- required: true
42
- },
43
- status: {
44
- type: String,
45
- enum: ['open', 'in_progress', 'pending_customer', 'escalated', 'resolved', 'closed', 'reopened', 'archived'],
46
- default: 'open'
47
- },
48
- category_id: {
49
- type: mongoose.Schema.Types.ObjectId,
50
- ref: 'TicketCategory',
51
- required: true
52
- },
53
- source: {
54
- type: String,
55
- enum: ['portal', 'email', 'phone', 'chat', 'in_person', 'mobile_app'],
56
- default: 'portal'
57
- },
58
- custom_caller: {
59
- name: {
60
- type: String,
61
- trim: true
62
- },
63
- phone: {
64
- type: String,
65
- trim: true
66
- },
67
- email: {
68
- type: String,
69
- trim: true
70
- },
71
- relationship: {
72
- type: String,
73
- trim: true,
74
- comment: 'Relationship to customer (e.g., spouse, agent, caretaker)'
75
- }
76
- },
77
- survey_token: {
78
- type: String,
79
- unique: true,
80
- sparse: true,
81
- comment: 'Unique token for customer survey link'
82
- },
83
- survey_sent_at: {
84
- type: Date,
85
- comment: 'When the survey invitation was sent'
86
- },
87
- survey_completed_at: {
88
- type: Date,
89
- comment: 'When the customer completed the survey'
90
- },
91
- sla_status: {
92
- type: String,
93
- enum: ['within_sla', 'approaching_breach', 'breached'],
94
- default: 'within_sla'
95
- },
96
- sla_due_date: {
97
- type: Date
98
- },
99
- first_response_time: {
100
- type: Number,
101
- comment: 'Time to first response in minutes'
102
- },
103
- resolution_time: {
104
- type: Number,
105
- comment: 'Time to resolution in minutes'
106
- },
107
- customer_rating: {
108
- type: Number,
109
- min: 1,
110
- max: 5
111
- },
112
- customer_feedback: {
113
- type: String,
114
- trim: true
115
- },
116
- tags: [{
117
- type: String,
118
- trim: true
119
- }],
120
- attachments: [{
121
- filename: String,
122
- file_path: String,
123
- file_size: Number,
124
- mime_type: String,
125
- uploaded_at: {
126
- type: Date,
127
- default: Date.now
128
- }
129
- }],
130
- interactions: [{
131
- agent_id: {
132
- type: mongoose.Schema.Types.ObjectId,
133
- ref: 'User'
134
- },
135
- message: String,
136
- is_internal_note: {
137
- type: Boolean,
138
- default: false
139
- },
140
- tagged_agents: [{
141
- type: mongoose.Schema.Types.ObjectId,
142
- ref: 'User'
143
- }],
144
- created_at: {
145
- type: Date,
146
- default: Date.now
147
- }
148
- }],
149
- reopened_count: {
150
- type: Number,
151
- default: 0,
152
- min: 0
153
- },
154
- last_reopened_at: {
155
- type: Date
156
- },
157
- resolved_at: {
158
- type: Date
159
- },
160
- resolved_by: {
161
- type: mongoose.Schema.Types.ObjectId,
162
- ref: 'User'
163
- },
164
- closed_at: {
165
- type: Date
166
- },
167
- escalated_at: {
168
- type: Date
169
- },
170
- escalated_to: {
171
- type: mongoose.Schema.Types.ObjectId,
172
- ref: 'User'
173
- },
174
- escalation_reason: {
175
- type: String
176
- },
177
- audit_log: [{
178
- user_id: {
179
- type: mongoose.Schema.Types.ObjectId,
180
- ref: 'User'
181
- },
182
- user_name: String,
183
- user_role: String,
184
- action: {
185
- type: String,
186
- enum: [
187
- 'created', 'updated', 'status_changed', 'assigned', 'reassigned',
188
- 'escalated', 'auto_escalated', 'resolved', 'closed', 'reopened',
189
- 'category_changed', 'priority_changed', 'sla_updated',
190
- 'interaction_added', 'attachment_added', 'tag_added', 'tag_removed',
191
- 'customer_response', 'agent_note'
192
- ]
193
- },
194
- field_changed: String,
195
- old_value: mongoose.Schema.Types.Mixed,
196
- new_value: mongoose.Schema.Types.Mixed,
197
- description: String,
198
- ip_address: String,
199
- user_agent: String,
200
- metadata: mongoose.Schema.Types.Mixed,
201
- timestamp: {
202
- type: Date,
203
- default: Date.now
204
- }
205
- }],
206
- activity_log: [{
207
- agent_id: {
208
- type: mongoose.Schema.Types.ObjectId,
209
- ref: 'User'
210
- },
211
- action: String,
212
- description: String,
213
- metadata: mongoose.Schema.Types.Mixed,
214
- timestamp: {
215
- type: Date,
216
- default: Date.now
217
- }
218
- }],
219
- created_at: {
220
- type: Date,
221
- default: Date.now
222
- },
223
- updated_at: {
224
- type: Date,
225
- default: Date.now
226
- }
227
- }, {
228
- timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' }
229
- });
230
-
231
- customerTicketSchema.index({ ticket_number: 1 });
232
- customerTicketSchema.index({ facility_id: 1, status: 1 });
233
- customerTicketSchema.index({ customer_id: 1, created_at: -1 });
234
- customerTicketSchema.index({ assigned_agent_id: 1, status: 1 });
235
- customerTicketSchema.index({ status: 1, sla_status: 1 });
236
- customerTicketSchema.index({ category_id: 1, created_at: -1 });
237
- customerTicketSchema.index({ sla_status: 1, sla_due_date: 1 });
238
-
239
- module.exports = mongoose.model('CustomerTicket', customerTicketSchema);
1
+ const mongoose = require('mongoose');
2
+
3
+ const customerTicketSchema = new mongoose.Schema({
4
+ ticket_number: {
5
+ type: String,
6
+ required: true,
7
+ unique: true,
8
+ trim: true
9
+ },
10
+ facility_id: {
11
+ type: mongoose.Schema.Types.ObjectId,
12
+ ref: 'Facility',
13
+ required: true
14
+ },
15
+ customer_id: {
16
+ type: mongoose.Schema.Types.ObjectId,
17
+ ref: 'Customer',
18
+ required: true
19
+ },
20
+ unit_id: {
21
+ type: mongoose.Schema.Types.ObjectId,
22
+ ref: 'Unit'
23
+ },
24
+ assigned_agent_id: {
25
+ type: mongoose.Schema.Types.ObjectId,
26
+ ref: 'User'
27
+ },
28
+ created_by_agent_id: {
29
+ type: mongoose.Schema.Types.ObjectId,
30
+ ref: 'User',
31
+ required: true
32
+ },
33
+ title: {
34
+ type: String,
35
+ required: true,
36
+ trim: true,
37
+ maxlength: 255
38
+ },
39
+ description: {
40
+ type: String,
41
+ required: true
42
+ },
43
+ status: {
44
+ type: String,
45
+ enum: ['open', 'in_progress', 'pending_customer', 'escalated', 'resolved', 'closed', 'reopened', 'archived'],
46
+ default: 'open'
47
+ },
48
+ category_id: {
49
+ type: mongoose.Schema.Types.ObjectId,
50
+ ref: 'TicketCategory',
51
+ required: true
52
+ },
53
+ source: {
54
+ type: String,
55
+ enum: ['portal', 'email', 'phone', 'chat', 'in_person', 'mobile_app'],
56
+ default: 'portal'
57
+ },
58
+ custom_caller: {
59
+ name: {
60
+ type: String,
61
+ trim: true
62
+ },
63
+ phone: {
64
+ type: String,
65
+ trim: true
66
+ },
67
+ email: {
68
+ type: String,
69
+ trim: true
70
+ },
71
+ relationship: {
72
+ type: String,
73
+ trim: true,
74
+ comment: 'Relationship to customer (e.g., spouse, agent, caretaker)'
75
+ }
76
+ },
77
+ survey_token: {
78
+ type: String,
79
+ unique: true,
80
+ sparse: true,
81
+ comment: 'Unique token for customer survey link'
82
+ },
83
+ survey_sent_at: {
84
+ type: Date,
85
+ comment: 'When the survey invitation was sent'
86
+ },
87
+ survey_completed_at: {
88
+ type: Date,
89
+ comment: 'When the customer completed the survey'
90
+ },
91
+ sla_status: {
92
+ type: String,
93
+ enum: ['within_sla', 'approaching_breach', 'breached'],
94
+ default: 'within_sla'
95
+ },
96
+ sla_due_date: {
97
+ type: Date
98
+ },
99
+ first_response_time: {
100
+ type: Number,
101
+ comment: 'Time to first response in minutes'
102
+ },
103
+ resolution_time: {
104
+ type: Number,
105
+ comment: 'Time to resolution in minutes'
106
+ },
107
+ customer_rating: {
108
+ type: Number,
109
+ min: 1,
110
+ max: 5
111
+ },
112
+ customer_feedback: {
113
+ type: String,
114
+ trim: true
115
+ },
116
+ tags: [{
117
+ type: String,
118
+ trim: true
119
+ }],
120
+ attachments: [{
121
+ filename: String,
122
+ file_path: String,
123
+ file_size: Number,
124
+ mime_type: String,
125
+ uploaded_at: {
126
+ type: Date,
127
+ default: Date.now
128
+ }
129
+ }],
130
+ interactions: [{
131
+ agent_id: {
132
+ type: mongoose.Schema.Types.ObjectId,
133
+ ref: 'User'
134
+ },
135
+ message: String,
136
+ is_internal_note: {
137
+ type: Boolean,
138
+ default: false
139
+ },
140
+ tagged_agents: [{
141
+ type: mongoose.Schema.Types.ObjectId,
142
+ ref: 'User'
143
+ }],
144
+ created_at: {
145
+ type: Date,
146
+ default: Date.now
147
+ }
148
+ }],
149
+ reopened_count: {
150
+ type: Number,
151
+ default: 0,
152
+ min: 0
153
+ },
154
+ last_reopened_at: {
155
+ type: Date
156
+ },
157
+ resolved_at: {
158
+ type: Date
159
+ },
160
+ resolved_by: {
161
+ type: mongoose.Schema.Types.ObjectId,
162
+ ref: 'User'
163
+ },
164
+ closed_at: {
165
+ type: Date
166
+ },
167
+ escalated_at: {
168
+ type: Date
169
+ },
170
+ escalated_to: {
171
+ type: mongoose.Schema.Types.ObjectId,
172
+ ref: 'User'
173
+ },
174
+ escalation_reason: {
175
+ type: String
176
+ },
177
+ audit_log: [{
178
+ user_id: {
179
+ type: mongoose.Schema.Types.ObjectId,
180
+ ref: 'User'
181
+ },
182
+ user_name: String,
183
+ user_role: String,
184
+ action: {
185
+ type: String,
186
+ enum: [
187
+ 'created', 'updated', 'status_changed', 'assigned', 'reassigned',
188
+ 'escalated', 'auto_escalated', 'resolved', 'closed', 'reopened',
189
+ 'category_changed', 'priority_changed', 'sla_updated',
190
+ 'interaction_added', 'attachment_added', 'tag_added', 'tag_removed',
191
+ 'customer_response', 'agent_note'
192
+ ]
193
+ },
194
+ field_changed: String,
195
+ old_value: mongoose.Schema.Types.Mixed,
196
+ new_value: mongoose.Schema.Types.Mixed,
197
+ description: String,
198
+ ip_address: String,
199
+ user_agent: String,
200
+ metadata: mongoose.Schema.Types.Mixed,
201
+ timestamp: {
202
+ type: Date,
203
+ default: Date.now
204
+ }
205
+ }],
206
+ activity_log: [{
207
+ agent_id: {
208
+ type: mongoose.Schema.Types.ObjectId,
209
+ ref: 'User'
210
+ },
211
+ action: String,
212
+ description: String,
213
+ metadata: mongoose.Schema.Types.Mixed,
214
+ timestamp: {
215
+ type: Date,
216
+ default: Date.now
217
+ }
218
+ }],
219
+ created_at: {
220
+ type: Date,
221
+ default: Date.now
222
+ },
223
+ updated_at: {
224
+ type: Date,
225
+ default: Date.now
226
+ }
227
+ }, {
228
+ timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' }
229
+ });
230
+
231
+ customerTicketSchema.index({ ticket_number: 1 });
232
+ customerTicketSchema.index({ facility_id: 1, status: 1 });
233
+ customerTicketSchema.index({ customer_id: 1, created_at: -1 });
234
+ customerTicketSchema.index({ assigned_agent_id: 1, status: 1 });
235
+ customerTicketSchema.index({ status: 1, sla_status: 1 });
236
+ customerTicketSchema.index({ category_id: 1, created_at: -1 });
237
+ customerTicketSchema.index({ sla_status: 1, sla_due_date: 1 });
238
+
239
+ module.exports = mongoose.model('CustomerTicket', customerTicketSchema);