payservedb 8.9.0 → 8.9.2

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 (193) hide show
  1. package/.env +2 -2
  2. package/ZOHO_INTEGRATION_SCHEMA.md +644 -644
  3. package/index.js +327 -326
  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 +179 -179
  23. package/src/models/bookingreservation.js +239 -239
  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 +290 -290
  29. package/src/models/combinedUnits.js +62 -62
  30. package/src/models/combined_invoice.js +424 -424
  31. package/src/models/common_area_electricity.js +38 -38
  32. package/src/models/common_area_generator.js +41 -41
  33. package/src/models/common_area_utility_alert.js +37 -37
  34. package/src/models/common_area_water.js +39 -39
  35. package/src/models/communication_status.js +33 -33
  36. package/src/models/communication_user_opt.js +32 -32
  37. package/src/models/community_guidelines.js +35 -35
  38. package/src/models/company.js +53 -53
  39. package/src/models/coreBaseSettings.js +16 -16
  40. package/src/models/coreInvoiceSettings.js +100 -100
  41. package/src/models/counter_schema.js +21 -21
  42. package/src/models/country_tax.js +42 -42
  43. package/src/models/currency_settings.js +39 -39
  44. package/src/models/customer.js +214 -214
  45. package/src/models/customer_preference.js +52 -52
  46. package/src/models/customer_satisfaction_survey.js +297 -297
  47. package/src/models/customer_surveys.js +139 -139
  48. package/src/models/customer_tickets.js +237 -237
  49. package/src/models/dailyChecklist.js +312 -312
  50. package/src/models/default_payment_details.js +17 -17
  51. package/src/models/deliveryTimeMarks.js +18 -18
  52. package/src/models/document_type.js +19 -19
  53. package/src/models/dutyRosterChecklist.js +250 -250
  54. package/src/models/dutyroster.js +136 -136
  55. package/src/models/email.js +37 -37
  56. package/src/models/email_sms_queue.js +61 -61
  57. package/src/models/email_thread.js +35 -35
  58. package/src/models/entry_exit.js +53 -53
  59. package/src/models/expense.js +99 -99
  60. package/src/models/expense_category.js +45 -45
  61. package/src/models/facility.js +76 -76
  62. package/src/models/facilityBillingPrices.js +29 -29
  63. package/src/models/facilityInvoice.js +240 -240
  64. package/src/models/facilityInvoicePayment.js +52 -52
  65. package/src/models/facilityInvoiceRecipient.js +32 -32
  66. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  67. package/src/models/facility_departements.js +20 -20
  68. package/src/models/facility_payment_details.js +20 -20
  69. package/src/models/facility_rating.js +78 -78
  70. package/src/models/facilityasset.js +25 -25
  71. package/src/models/faq.js +14 -14
  72. package/src/models/gl_account_double_entries.js +25 -25
  73. package/src/models/gl_accounts.js +56 -56
  74. package/src/models/gl_entries.js +49 -49
  75. package/src/models/goodsReceivedNotes.js +115 -115
  76. package/src/models/guard.js +47 -47
  77. package/src/models/handover.js +258 -258
  78. package/src/models/inspection_category.js +38 -38
  79. package/src/models/invoice.js +484 -480
  80. package/src/models/invoice_generation_approval.js +86 -86
  81. package/src/models/invoicing_schedule.js +40 -40
  82. package/src/models/item_inspection.js +96 -96
  83. package/src/models/knowledge_base.js +109 -109
  84. package/src/models/knowledge_base_rating.js +44 -44
  85. package/src/models/leaseagreement.js +243 -243
  86. package/src/models/leasetemplate.js +17 -17
  87. package/src/models/levy.js +223 -223
  88. package/src/models/levy_invoice_settings.js +26 -26
  89. package/src/models/levycontract.js +216 -216
  90. package/src/models/levytype.js +23 -23
  91. package/src/models/maintenance_service_vendor.js +38 -38
  92. package/src/models/maintenance_services.js +17 -17
  93. package/src/models/maintenancerequisition.js +31 -31
  94. package/src/models/master_workplan.js +32 -32
  95. package/src/models/master_workplan_child.js +34 -34
  96. package/src/models/message.js +38 -38
  97. package/src/models/module.js +21 -21
  98. package/src/models/movein_application.js +29 -29
  99. package/src/models/movein_landlord.js +18 -18
  100. package/src/models/movein_user.js +15 -15
  101. package/src/models/notification.js +44 -44
  102. package/src/models/paymentTermsMarks.js +19 -19
  103. package/src/models/penalty.js +76 -76
  104. package/src/models/pendingCredentials.js +32 -32
  105. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  106. package/src/models/powerMeterCustomerAccount.js +78 -78
  107. package/src/models/powerMeterCustomerBand.js +14 -14
  108. package/src/models/powerMeterDailyReading.js +30 -30
  109. package/src/models/powerMeterGateways.js +40 -40
  110. package/src/models/powerMeterMonthlyReading.js +34 -34
  111. package/src/models/powerMeterPowerCharges.js +85 -85
  112. package/src/models/powerMeterSettings.js +159 -159
  113. package/src/models/powerMeterSingleDayReading.js +32 -32
  114. package/src/models/powerMeters.js +116 -116
  115. package/src/models/powerMetersManufacturer.js +14 -14
  116. package/src/models/power_invoice.js +471 -0
  117. package/src/models/power_meter_account.js +81 -81
  118. package/src/models/power_meter_command_logs.js +30 -30
  119. package/src/models/power_meter_command_queue.js +33 -33
  120. package/src/models/power_meter_negative_balance.js +44 -44
  121. package/src/models/power_prepaid_credits.js +47 -47
  122. package/src/models/power_prepaid_debits.js +53 -53
  123. package/src/models/power_prepaid_orders.js +78 -78
  124. package/src/models/power_sms_notification.js +26 -26
  125. package/src/models/privacy_policy.js +19 -19
  126. package/src/models/propertyManagerContract.js +556 -556
  127. package/src/models/propertyManagerRevenue.js +195 -195
  128. package/src/models/purchaseOrderInvoice.js +74 -74
  129. package/src/models/purchase_order.js +213 -213
  130. package/src/models/purchase_request.js +110 -110
  131. package/src/models/quickbooks_config.js +52 -52
  132. package/src/models/refresh_token.js +23 -23
  133. package/src/models/reminder.js +197 -197
  134. package/src/models/report.js +13 -13
  135. package/src/models/resident.js +121 -121
  136. package/src/models/rfq_details.js +131 -131
  137. package/src/models/rfq_response.js +153 -153
  138. package/src/models/service_charge_invoice_upload.js +42 -42
  139. package/src/models/service_charge_payments.js +27 -27
  140. package/src/models/servicerequest.js +55 -55
  141. package/src/models/settings.js +62 -62
  142. package/src/models/short_urls.js +21 -21
  143. package/src/models/smart_meter_daily_consumption.js +44 -44
  144. package/src/models/sms_africastalking.js +20 -20
  145. package/src/models/sms_balance_notification.js +26 -26
  146. package/src/models/sms_meliora.js +20 -20
  147. package/src/models/staff.js +36 -36
  148. package/src/models/stocksandspare.js +161 -161
  149. package/src/models/suppliers.js +74 -74
  150. package/src/models/terms_and_conditions.js +19 -19
  151. package/src/models/tickets.js +186 -186
  152. package/src/models/tickets_category.js +72 -72
  153. package/src/models/unitManagementTemplate.js +44 -44
  154. package/src/models/unitasset.js +25 -25
  155. package/src/models/units.js +130 -130
  156. package/src/models/user.js +186 -186
  157. package/src/models/valueaddedservices.js +21 -21
  158. package/src/models/vas_invoices_upload.js +50 -50
  159. package/src/models/vas_payments.js +24 -24
  160. package/src/models/vasinvoice.js +192 -192
  161. package/src/models/vasvendor.js +52 -52
  162. package/src/models/visitLog.js +95 -95
  163. package/src/models/visitor.js +67 -67
  164. package/src/models/waitlist.js +45 -45
  165. package/src/models/wallet.js +44 -44
  166. package/src/models/wallet_transactions.js +50 -50
  167. package/src/models/water_invoice.js +351 -351
  168. package/src/models/water_meter_Command_Queue.js +33 -33
  169. package/src/models/water_meter_account.js +86 -86
  170. package/src/models/water_meter_billing.js +58 -58
  171. package/src/models/water_meter_combined_accounts.js +92 -92
  172. package/src/models/water_meter_communication.js +17 -17
  173. package/src/models/water_meter_communication_logs.js +39 -39
  174. package/src/models/water_meter_concentrator.js +70 -70
  175. package/src/models/water_meter_daily_history.js +32 -32
  176. package/src/models/water_meter_high_risk.js +36 -36
  177. package/src/models/water_meter_iot_cards.js +34 -34
  178. package/src/models/water_meter_loan_deduction.js +134 -134
  179. package/src/models/water_meter_manufacturer.js +35 -35
  180. package/src/models/water_meter_monthly_history.js +36 -36
  181. package/src/models/water_meter_negative_amounts.js +44 -44
  182. package/src/models/water_meter_settings.js +290 -290
  183. package/src/models/water_meter_single_day_history.js +34 -34
  184. package/src/models/water_meter_size.js +15 -15
  185. package/src/models/water_meters.js +176 -176
  186. package/src/models/water_meters_delivery.js +76 -76
  187. package/src/models/water_prepaid_credit.js +47 -47
  188. package/src/models/water_prepaid_debit.js +50 -50
  189. package/src/models/whatsapp_conversation.js +23 -23
  190. package/src/models/workorder.js +49 -49
  191. package/src/models/zohoAccount.js +453 -453
  192. package/src/models/zohoIntegration.js +262 -262
  193. package/src/models/zohoItem.js +504 -504
@@ -1,87 +1,87 @@
1
- const mongoose = require('mongoose');
2
-
3
- const invoiceGenerationSchema = new mongoose.Schema(
4
- {
5
- invoiceType: {
6
- type: String,
7
- enum: ['levy', 'lease'],
8
- required: true
9
- },
10
- facility: {
11
- id: {
12
- type: mongoose.Schema.Types.ObjectId,
13
- ref: "Facility",
14
- required: true
15
- },
16
- name: {
17
- type: String,
18
- required: true,
19
- trim: true
20
- }
21
- },
22
- yearMonth: {
23
- type: String,
24
- required: true,
25
- trim: true
26
- },
27
- generationDate: {
28
- type: Date,
29
- required: true,
30
- default: Date.now
31
- },
32
- approvalStatus: {
33
- type: String,
34
- enum: ['Pending', 'Approved', 'Rejected'],
35
- default: 'Pending'
36
- },
37
- approvedBy: {
38
- userId: mongoose.Schema.Types.ObjectId,
39
- name: String,
40
- approvalDate: Date,
41
- comments: String
42
- },
43
- rejectedBy: {
44
- userId: mongoose.Schema.Types.ObjectId,
45
- name: String,
46
- rejectionDate: Date,
47
- reason: String
48
- },
49
- metadata: {
50
- createdBy: {
51
- type: mongoose.Schema.Types.ObjectId
52
- },
53
- source: {
54
- type: String,
55
- enum: ['manual', 'api', 'import', 'mobile'],
56
- default: 'manual'
57
- },
58
- deviceInfo: {
59
- deviceId: String,
60
- deviceType: String,
61
- ipAddress: String
62
- }
63
- }
64
- },
65
- {
66
- timestamps: true
67
- }
68
- );
69
-
70
- // Static methods
71
- invoiceGenerationSchema.statics.findPendingGenerations = function (facilityId) {
72
- return this.find({
73
- 'facility.id': facilityId,
74
- 'approvalStatus': 'Pending'
75
- }).sort({ generationDate: -1 });
76
- };
77
-
78
- invoiceGenerationSchema.statics.findByType = function (invoiceType, facilityId) {
79
- return this.find({
80
- 'facility.id': facilityId,
81
- 'invoiceType': invoiceType
82
- }).sort({ generationDate: -1 });
83
- };
84
-
85
- const InvoiceGeneration = mongoose.model('InvoiceGeneration', invoiceGenerationSchema);
86
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const invoiceGenerationSchema = new mongoose.Schema(
4
+ {
5
+ invoiceType: {
6
+ type: String,
7
+ enum: ['levy', 'lease'],
8
+ required: true
9
+ },
10
+ facility: {
11
+ id: {
12
+ type: mongoose.Schema.Types.ObjectId,
13
+ ref: "Facility",
14
+ required: true
15
+ },
16
+ name: {
17
+ type: String,
18
+ required: true,
19
+ trim: true
20
+ }
21
+ },
22
+ yearMonth: {
23
+ type: String,
24
+ required: true,
25
+ trim: true
26
+ },
27
+ generationDate: {
28
+ type: Date,
29
+ required: true,
30
+ default: Date.now
31
+ },
32
+ approvalStatus: {
33
+ type: String,
34
+ enum: ['Pending', 'Approved', 'Rejected'],
35
+ default: 'Pending'
36
+ },
37
+ approvedBy: {
38
+ userId: mongoose.Schema.Types.ObjectId,
39
+ name: String,
40
+ approvalDate: Date,
41
+ comments: String
42
+ },
43
+ rejectedBy: {
44
+ userId: mongoose.Schema.Types.ObjectId,
45
+ name: String,
46
+ rejectionDate: Date,
47
+ reason: String
48
+ },
49
+ metadata: {
50
+ createdBy: {
51
+ type: mongoose.Schema.Types.ObjectId
52
+ },
53
+ source: {
54
+ type: String,
55
+ enum: ['manual', 'api', 'import', 'mobile'],
56
+ default: 'manual'
57
+ },
58
+ deviceInfo: {
59
+ deviceId: String,
60
+ deviceType: String,
61
+ ipAddress: String
62
+ }
63
+ }
64
+ },
65
+ {
66
+ timestamps: true
67
+ }
68
+ );
69
+
70
+ // Static methods
71
+ invoiceGenerationSchema.statics.findPendingGenerations = function (facilityId) {
72
+ return this.find({
73
+ 'facility.id': facilityId,
74
+ 'approvalStatus': 'Pending'
75
+ }).sort({ generationDate: -1 });
76
+ };
77
+
78
+ invoiceGenerationSchema.statics.findByType = function (invoiceType, facilityId) {
79
+ return this.find({
80
+ 'facility.id': facilityId,
81
+ 'invoiceType': invoiceType
82
+ }).sort({ generationDate: -1 });
83
+ };
84
+
85
+ const InvoiceGeneration = mongoose.model('InvoiceGeneration', invoiceGenerationSchema);
86
+
87
87
  module.exports = InvoiceGeneration;
@@ -1,41 +1,41 @@
1
- const mongoose = require('mongoose');
2
-
3
- const InvoicingScheduleSchema = new mongoose.Schema({
4
- facilityId: {
5
- type: mongoose.Schema.Types.ObjectId,
6
- ref: 'Facility',
7
- },
8
- nextInvoiceDate: {
9
- type: Date,
10
- required: true
11
- },
12
- invoiceType: {
13
- type: String,
14
- required: true,
15
- unique: true,
16
- trim: true,
17
- index: true
18
- },
19
- isAutomatic: {
20
- type: Boolean,
21
- required: true,
22
- default: true
23
- },
24
- createdAt: {
25
- type: Date,
26
- default: Date.now
27
- },
28
- updatedAt: {
29
- type: Date,
30
- default: Date.now
31
- }
32
- });
33
-
34
- InvoicingScheduleSchema.pre('save', function(next) {
35
- this.updatedAt = Date.now();
36
- next();
37
- });
38
-
39
- const InvoicingSchedule = mongoose.model('InvoicingSchedule', InvoicingScheduleSchema);
40
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const InvoicingScheduleSchema = new mongoose.Schema({
4
+ facilityId: {
5
+ type: mongoose.Schema.Types.ObjectId,
6
+ ref: 'Facility',
7
+ },
8
+ nextInvoiceDate: {
9
+ type: Date,
10
+ required: true
11
+ },
12
+ invoiceType: {
13
+ type: String,
14
+ required: true,
15
+ unique: true,
16
+ trim: true,
17
+ index: true
18
+ },
19
+ isAutomatic: {
20
+ type: Boolean,
21
+ required: true,
22
+ default: true
23
+ },
24
+ createdAt: {
25
+ type: Date,
26
+ default: Date.now
27
+ },
28
+ updatedAt: {
29
+ type: Date,
30
+ default: Date.now
31
+ }
32
+ });
33
+
34
+ InvoicingScheduleSchema.pre('save', function(next) {
35
+ this.updatedAt = Date.now();
36
+ next();
37
+ });
38
+
39
+ const InvoicingSchedule = mongoose.model('InvoicingSchedule', InvoicingScheduleSchema);
40
+
41
41
  module.exports = InvoicingSchedule;
@@ -1,97 +1,97 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for inspection items
4
- const inspectionItemSchema = new mongoose.Schema({
5
- name: {
6
- type: String,
7
- required: [true, 'Item name is required'],
8
- trim: true
9
- },
10
- category: {
11
- type: String,
12
- required: [true, 'Category is required'],
13
- trim: true
14
- },
15
- subcategory: {
16
- type: String,
17
- trim: true,
18
- default: null
19
- },
20
- description: {
21
- type: String,
22
- trim: true
23
- },
24
- possibleConditions: {
25
- type: [String],
26
- default: ['Excellent', 'Good', 'Fair', 'Poor', 'Damaged', 'Non-functional'],
27
- validate: {
28
- validator: function(v) {
29
- return v.length > 0;
30
- },
31
- message: 'At least one possible condition is required'
32
- }
33
- },
34
- defaultCondition: {
35
- type: String,
36
- default: 'Good'
37
- },
38
- isRequired: {
39
- type: Boolean,
40
- default: true
41
- },
42
- defaultQuantity: {
43
- type: Number,
44
- default: 1,
45
- min: [1, 'Default quantity must be at least 1']
46
- },
47
- serialNumber: {
48
- type: String,
49
- trim: true,
50
- default: null
51
- },
52
- cost: {
53
- type: Number,
54
- default: 0,
55
- min: [0, 'Cost cannot be negative']
56
- },
57
- currencyId: {
58
- type: mongoose.Schema.Types.ObjectId,
59
- ref: 'Currency',
60
- required: false,
61
- default: null
62
- },
63
- images: [{
64
- type: String,
65
- trim: true
66
- }],
67
- active: {
68
- type: Boolean,
69
- default: true
70
- },
71
- facilityId: {
72
- type: mongoose.Schema.Types.ObjectId,
73
- ref: 'Facility',
74
- required: true
75
- },
76
- unitId: {
77
- type: mongoose.Schema.Types.ObjectId,
78
- ref: 'Unit',
79
- required: false,
80
- default: null
81
- }
82
- }, {
83
- timestamps: true
84
- });
85
-
86
- // Add indexes for common queries
87
- inspectionItemSchema.index({ facilityId: 1 });
88
- inspectionItemSchema.index({ facilityId: 1, category: 1 });
89
- inspectionItemSchema.index({ facilityId: 1, active: 1 });
90
- inspectionItemSchema.index({ facilityId: 1, unitId: 1 });
91
- inspectionItemSchema.index({ unitId: 1, active: 1 });
92
- inspectionItemSchema.index({ currencyId: 1 });
93
-
94
- // Create InspectionItem model
95
- const InspectionItem = mongoose.model('InspectionItem', inspectionItemSchema);
96
-
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for inspection items
4
+ const inspectionItemSchema = new mongoose.Schema({
5
+ name: {
6
+ type: String,
7
+ required: [true, 'Item name is required'],
8
+ trim: true
9
+ },
10
+ category: {
11
+ type: String,
12
+ required: [true, 'Category is required'],
13
+ trim: true
14
+ },
15
+ subcategory: {
16
+ type: String,
17
+ trim: true,
18
+ default: null
19
+ },
20
+ description: {
21
+ type: String,
22
+ trim: true
23
+ },
24
+ possibleConditions: {
25
+ type: [String],
26
+ default: ['Excellent', 'Good', 'Fair', 'Poor', 'Damaged', 'Non-functional'],
27
+ validate: {
28
+ validator: function(v) {
29
+ return v.length > 0;
30
+ },
31
+ message: 'At least one possible condition is required'
32
+ }
33
+ },
34
+ defaultCondition: {
35
+ type: String,
36
+ default: 'Good'
37
+ },
38
+ isRequired: {
39
+ type: Boolean,
40
+ default: true
41
+ },
42
+ defaultQuantity: {
43
+ type: Number,
44
+ default: 1,
45
+ min: [1, 'Default quantity must be at least 1']
46
+ },
47
+ serialNumber: {
48
+ type: String,
49
+ trim: true,
50
+ default: null
51
+ },
52
+ cost: {
53
+ type: Number,
54
+ default: 0,
55
+ min: [0, 'Cost cannot be negative']
56
+ },
57
+ currencyId: {
58
+ type: mongoose.Schema.Types.ObjectId,
59
+ ref: 'Currency',
60
+ required: false,
61
+ default: null
62
+ },
63
+ images: [{
64
+ type: String,
65
+ trim: true
66
+ }],
67
+ active: {
68
+ type: Boolean,
69
+ default: true
70
+ },
71
+ facilityId: {
72
+ type: mongoose.Schema.Types.ObjectId,
73
+ ref: 'Facility',
74
+ required: true
75
+ },
76
+ unitId: {
77
+ type: mongoose.Schema.Types.ObjectId,
78
+ ref: 'Unit',
79
+ required: false,
80
+ default: null
81
+ }
82
+ }, {
83
+ timestamps: true
84
+ });
85
+
86
+ // Add indexes for common queries
87
+ inspectionItemSchema.index({ facilityId: 1 });
88
+ inspectionItemSchema.index({ facilityId: 1, category: 1 });
89
+ inspectionItemSchema.index({ facilityId: 1, active: 1 });
90
+ inspectionItemSchema.index({ facilityId: 1, unitId: 1 });
91
+ inspectionItemSchema.index({ unitId: 1, active: 1 });
92
+ inspectionItemSchema.index({ currencyId: 1 });
93
+
94
+ // Create InspectionItem model
95
+ const InspectionItem = mongoose.model('InspectionItem', inspectionItemSchema);
96
+
97
97
  module.exports = InspectionItem;
@@ -1,109 +1,109 @@
1
- const mongoose = require('mongoose');
2
-
3
- const knowledgeBaseSchema = new mongoose.Schema({
4
- title: {
5
- type: String,
6
- required: true,
7
- trim: true,
8
- maxlength: 255
9
- },
10
- content: {
11
- type: String,
12
- required: true
13
- },
14
- summary: {
15
- type: String,
16
- trim: true,
17
- maxlength: 500
18
- },
19
- category_id: {
20
- type: mongoose.Schema.Types.ObjectId,
21
- ref: 'TicketCategory',
22
- required: true
23
- },
24
- tags: [{
25
- type: String,
26
- trim: true
27
- }],
28
- status: {
29
- type: String,
30
- enum: ['draft', 'published', 'archived'],
31
- default: 'draft'
32
- },
33
- visibility: {
34
- type: String,
35
- enum: ['internal', 'public'],
36
- default: 'internal'
37
- },
38
- is_featured: {
39
- type: Boolean,
40
- default: false
41
- },
42
- author_id: {
43
- type: mongoose.Schema.Types.ObjectId,
44
- ref: 'User',
45
- required: true
46
- },
47
- created_by: {
48
- type: mongoose.Schema.Types.ObjectId,
49
- ref: 'User',
50
- required: true
51
- },
52
- updated_by: {
53
- type: mongoose.Schema.Types.ObjectId,
54
- ref: 'User'
55
- },
56
- views_count: {
57
- type: Number,
58
- default: 0,
59
- min: 0
60
- },
61
- helpful_count: {
62
- type: Number,
63
- default: 0,
64
- min: 0
65
- },
66
- not_helpful_count: {
67
- type: Number,
68
- default: 0,
69
- min: 0
70
- },
71
- attachments: [{
72
- filename: String,
73
- file_path: String,
74
- file_size: Number,
75
- mime_type: String,
76
- uploaded_at: {
77
- type: Date,
78
- default: Date.now
79
- }
80
- }],
81
- related_articles: [{
82
- type: mongoose.Schema.Types.ObjectId,
83
- ref: 'KnowledgeBase'
84
- }],
85
- created_at: {
86
- type: Date,
87
- default: Date.now
88
- },
89
- updated_at: {
90
- type: Date,
91
- default: Date.now
92
- },
93
- published_at: {
94
- type: Date
95
- },
96
- archived_at: {
97
- type: Date
98
- }
99
- }, {
100
- timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' }
101
- });
102
-
103
- knowledgeBaseSchema.index({ title: 'text', content: 'text', summary: 'text', tags: 'text' });
104
- knowledgeBaseSchema.index({ category_id: 1, status: 1 });
105
- knowledgeBaseSchema.index({ status: 1, is_featured: 1 });
106
- knowledgeBaseSchema.index({ author_id: 1, created_at: -1 });
107
- knowledgeBaseSchema.index({ views_count: -1 });
108
-
109
- module.exports = mongoose.model('KnowledgeBase', knowledgeBaseSchema);
1
+ const mongoose = require('mongoose');
2
+
3
+ const knowledgeBaseSchema = new mongoose.Schema({
4
+ title: {
5
+ type: String,
6
+ required: true,
7
+ trim: true,
8
+ maxlength: 255
9
+ },
10
+ content: {
11
+ type: String,
12
+ required: true
13
+ },
14
+ summary: {
15
+ type: String,
16
+ trim: true,
17
+ maxlength: 500
18
+ },
19
+ category_id: {
20
+ type: mongoose.Schema.Types.ObjectId,
21
+ ref: 'TicketCategory',
22
+ required: true
23
+ },
24
+ tags: [{
25
+ type: String,
26
+ trim: true
27
+ }],
28
+ status: {
29
+ type: String,
30
+ enum: ['draft', 'published', 'archived'],
31
+ default: 'draft'
32
+ },
33
+ visibility: {
34
+ type: String,
35
+ enum: ['internal', 'public'],
36
+ default: 'internal'
37
+ },
38
+ is_featured: {
39
+ type: Boolean,
40
+ default: false
41
+ },
42
+ author_id: {
43
+ type: mongoose.Schema.Types.ObjectId,
44
+ ref: 'User',
45
+ required: true
46
+ },
47
+ created_by: {
48
+ type: mongoose.Schema.Types.ObjectId,
49
+ ref: 'User',
50
+ required: true
51
+ },
52
+ updated_by: {
53
+ type: mongoose.Schema.Types.ObjectId,
54
+ ref: 'User'
55
+ },
56
+ views_count: {
57
+ type: Number,
58
+ default: 0,
59
+ min: 0
60
+ },
61
+ helpful_count: {
62
+ type: Number,
63
+ default: 0,
64
+ min: 0
65
+ },
66
+ not_helpful_count: {
67
+ type: Number,
68
+ default: 0,
69
+ min: 0
70
+ },
71
+ attachments: [{
72
+ filename: String,
73
+ file_path: String,
74
+ file_size: Number,
75
+ mime_type: String,
76
+ uploaded_at: {
77
+ type: Date,
78
+ default: Date.now
79
+ }
80
+ }],
81
+ related_articles: [{
82
+ type: mongoose.Schema.Types.ObjectId,
83
+ ref: 'KnowledgeBase'
84
+ }],
85
+ created_at: {
86
+ type: Date,
87
+ default: Date.now
88
+ },
89
+ updated_at: {
90
+ type: Date,
91
+ default: Date.now
92
+ },
93
+ published_at: {
94
+ type: Date
95
+ },
96
+ archived_at: {
97
+ type: Date
98
+ }
99
+ }, {
100
+ timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' }
101
+ });
102
+
103
+ knowledgeBaseSchema.index({ title: 'text', content: 'text', summary: 'text', tags: 'text' });
104
+ knowledgeBaseSchema.index({ category_id: 1, status: 1 });
105
+ knowledgeBaseSchema.index({ status: 1, is_featured: 1 });
106
+ knowledgeBaseSchema.index({ author_id: 1, created_at: -1 });
107
+ knowledgeBaseSchema.index({ views_count: -1 });
108
+
109
+ module.exports = mongoose.model('KnowledgeBase', knowledgeBaseSchema);