payservedb 4.3.9 → 4.4.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.
- package/.env +2 -2
- package/index.js +152 -152
- package/package.json +17 -17
- package/src/models/account.js +36 -36
- package/src/models/analog_water_billing.js +58 -58
- package/src/models/apilog.js +18 -18
- package/src/models/archivedapilog.js +18 -18
- package/src/models/archivedauditlog.js +83 -83
- package/src/models/asset.js +34 -34
- package/src/models/auditlog.js +83 -83
- package/src/models/bankdetails.js +40 -40
- package/src/models/budget.js +33 -33
- package/src/models/budgetCategory.js +19 -19
- package/src/models/campaigns.js +72 -72
- package/src/models/cashpayment.js +185 -185
- package/src/models/combinedUnits.js +62 -62
- package/src/models/company.js +53 -53
- package/src/models/country_tax.js +42 -42
- package/src/models/currency_settings.js +39 -39
- package/src/models/customer.js +181 -178
- package/src/models/default_payment_details.js +17 -17
- package/src/models/dutyroster.js +39 -39
- package/src/models/email.js +24 -24
- package/src/models/entry_exit.js +53 -53
- package/src/models/expense.js +55 -55
- package/src/models/facility.js +58 -58
- package/src/models/facility_payment_details.js +20 -20
- package/src/models/facilityasset.js +25 -25
- package/src/models/faq.js +18 -18
- package/src/models/guard.js +47 -47
- package/src/models/handover.js +241 -241
- package/src/models/invoice.js +252 -210
- package/src/models/item_inspection.js +67 -67
- package/src/models/leaseagreement.js +156 -156
- package/src/models/leasetemplate.js +17 -17
- package/src/models/levy.js +72 -72
- package/src/models/levy_invoice_settings.js +26 -26
- package/src/models/levycontract.js +65 -65
- package/src/models/levytype.js +23 -23
- package/src/models/maintenance_service_vendor.js +38 -38
- package/src/models/maintenance_services.js +17 -17
- package/src/models/maintenancerequisition.js +31 -31
- package/src/models/message.js +38 -38
- package/src/models/module.js +21 -21
- package/src/models/notification.js +24 -24
- package/src/models/penalty.js +76 -76
- package/src/models/refresh_token.js +23 -23
- package/src/models/reminder.js +161 -161
- package/src/models/report.js +13 -13
- package/src/models/resident.js +121 -121
- package/src/models/service_charge_invoice_upload.js +42 -42
- package/src/models/service_charge_payments.js +27 -27
- package/src/models/servicerequest.js +55 -55
- package/src/models/settings.js +62 -62
- package/src/models/smart_meter_daily_consumption.js +44 -44
- package/src/models/sms_africastalking.js +20 -20
- package/src/models/sms_meliora.js +16 -16
- package/src/models/staff.js +36 -36
- package/src/models/stocksandspare.js +34 -34
- package/src/models/tickets.js +109 -109
- package/src/models/unitasset.js +25 -25
- package/src/models/units.js +70 -70
- package/src/models/user.js +94 -94
- package/src/models/valueaddedservices.js +36 -36
- package/src/models/vas_invoices_upload.js +50 -50
- package/src/models/vas_payments.js +24 -24
- package/src/models/vasinvoice.js +159 -159
- package/src/models/vasvendor.js +57 -57
- package/src/models/visitLog.js +86 -86
- package/src/models/visitor.js +63 -63
- package/src/models/waitlist.js +45 -45
- package/src/models/water_invoice.js +192 -192
- package/src/models/water_meter_account.js +73 -74
- package/src/models/water_meter_communication.js +17 -17
- package/src/models/water_meter_concentrator.js +59 -59
- package/src/models/water_meter_iot_cards.js +34 -34
- package/src/models/water_meter_manufacturer.js +35 -35
- package/src/models/water_meter_settings.js +101 -88
- package/src/models/water_meter_size.js +15 -15
- package/src/models/water_meters.js +110 -110
- package/src/models/water_meters_delivery.js +76 -76
- 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,153 +1,153 @@
|
|
|
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}
|
|
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
|
-
CashPayment: require('./src/models/cashpayment'),
|
|
131
|
-
VasPayment: require('./src/models/vas_payments'),
|
|
132
|
-
VasInvoicesQuickBooks: require('./src/models/vas_invoices_upload'),
|
|
133
|
-
ServiceChargePayment: require('./src/models/service_charge_payments'),
|
|
134
|
-
ServiceChargeInvoiceUpload: require('./src/models/service_charge_invoice_upload'),
|
|
135
|
-
Campaign: require('./src/models/campaigns'),
|
|
136
|
-
InspectionItem: require('./src/models/item_inspection')
|
|
137
|
-
|
|
138
|
-
};
|
|
139
|
-
|
|
140
|
-
// Function to get models dynamically from a specific database connection
|
|
141
|
-
async function getModelFromDB(dbConnection, modelName, schema) {
|
|
142
|
-
if (!dbConnection.models[modelName]) {
|
|
143
|
-
return dbConnection.model(modelName, schema); // Register the model in the db connection
|
|
144
|
-
}
|
|
145
|
-
return dbConnection.models[modelName]; // Return existing model if already registered
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
module.exports = {
|
|
149
|
-
connectToMongoDB,
|
|
150
|
-
switchDB,
|
|
151
|
-
getModelFromDB,
|
|
152
|
-
...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
|
+
CashPayment: require('./src/models/cashpayment'),
|
|
131
|
+
VasPayment: require('./src/models/vas_payments'),
|
|
132
|
+
VasInvoicesQuickBooks: require('./src/models/vas_invoices_upload'),
|
|
133
|
+
ServiceChargePayment: require('./src/models/service_charge_payments'),
|
|
134
|
+
ServiceChargeInvoiceUpload: require('./src/models/service_charge_invoice_upload'),
|
|
135
|
+
Campaign: require('./src/models/campaigns'),
|
|
136
|
+
InspectionItem: require('./src/models/item_inspection')
|
|
137
|
+
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
// Function to get models dynamically from a specific database connection
|
|
141
|
+
async function getModelFromDB(dbConnection, modelName, schema) {
|
|
142
|
+
if (!dbConnection.models[modelName]) {
|
|
143
|
+
return dbConnection.model(modelName, schema); // Register the model in the db connection
|
|
144
|
+
}
|
|
145
|
+
return dbConnection.models[modelName]; // Return existing model if already registered
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
module.exports = {
|
|
149
|
+
connectToMongoDB,
|
|
150
|
+
switchDB,
|
|
151
|
+
getModelFromDB,
|
|
152
|
+
...models // Spread operator to export all models
|
|
153
153
|
}
|
package/package.json
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "payservedb",
|
|
3
|
-
"version": "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
|
+
{
|
|
2
|
+
"name": "payservedb",
|
|
3
|
+
"version": "4.4.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
|
+
}
|
package/src/models/account.js
CHANGED
|
@@ -1,37 +1,37 @@
|
|
|
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
|
-
// [ {accountnumber:1,facilityId:1},{accountnumber:2, facility:2}]
|
|
35
|
-
const Account = mongoose.model('Account', accountSchema);
|
|
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
|
+
// [ {accountnumber:1,facilityId:1},{accountnumber:2, facility:2}]
|
|
35
|
+
const Account = mongoose.model('Account', accountSchema);
|
|
36
|
+
|
|
37
37
|
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;
|
package/src/models/apilog.js
CHANGED
|
@@ -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;
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
const mongoose = require('mongoose');
|
|
3
|
-
const { Schema } = mongoose;
|
|
4
|
-
|
|
5
|
-
const ArchivedApiLogSchema = new Schema({
|
|
6
|
-
url: { type: String, required: true, index: true },
|
|
7
|
-
method: { type: String, required: true, enum: ['GET', 'POST', 'PUT', 'DELETE'], 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
|
-
ArchivedApiLogSchema.index({ time: 1 }, { expireAfterSeconds: 60 * 60 * 24 * 365 });
|
|
15
|
-
|
|
16
|
-
const ArchivedApiLog = mongoose.model('ArchivedApiLog', ArchivedApiLogSchema);
|
|
17
|
-
|
|
18
|
-
module.exports = ArchivedApiLog;
|
|
1
|
+
|
|
2
|
+
const mongoose = require('mongoose');
|
|
3
|
+
const { Schema } = mongoose;
|
|
4
|
+
|
|
5
|
+
const ArchivedApiLogSchema = new Schema({
|
|
6
|
+
url: { type: String, required: true, index: true },
|
|
7
|
+
method: { type: String, required: true, enum: ['GET', 'POST', 'PUT', 'DELETE'], 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
|
+
ArchivedApiLogSchema.index({ time: 1 }, { expireAfterSeconds: 60 * 60 * 24 * 365 });
|
|
15
|
+
|
|
16
|
+
const ArchivedApiLog = mongoose.model('ArchivedApiLog', ArchivedApiLogSchema);
|
|
17
|
+
|
|
18
|
+
module.exports = ArchivedApiLog;
|