@talkpilot/core-db 1.1.8 → 1.1.10
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/README.md +7 -0
- package/dist/connection.d.ts +1 -1
- package/dist/connection.d.ts.map +1 -1
- package/dist/connection.js +21 -24
- package/dist/connection.js.map +1 -1
- package/dist/index.d.ts +9 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/municipal/cities/cities.getters.d.ts +2 -2
- package/dist/municipal/cities/cities.getters.d.ts.map +1 -1
- package/dist/municipal/cities/cities.getters.js +8 -4
- package/dist/municipal/cities/cities.getters.js.map +1 -1
- package/dist/municipal/cities/cities.types.d.ts +1 -1
- package/dist/municipal/cities/index.d.ts +2 -2
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.d.ts +3 -3
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.d.ts.map +1 -1
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.js +30 -22
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.js.map +1 -1
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.d.ts +4 -4
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.d.ts.map +1 -1
- package/dist/municipal/departmentsSubjects/index.d.ts +2 -2
- package/dist/municipal/index.d.ts +8 -8
- package/dist/municipal/index.d.ts.map +1 -1
- package/dist/municipal/index.js +1 -1
- package/dist/municipal/mongodb-client.d.ts +1 -1
- package/dist/municipal/mongodb-client.d.ts.map +1 -1
- package/dist/municipal/mongodb-client.js +7 -7
- package/dist/municipal/mongodb-client.js.map +1 -1
- package/dist/municipal/streets/index.d.ts +2 -2
- package/dist/municipal/streets/streets.getters.d.ts +3 -3
- package/dist/municipal/streets/streets.getters.d.ts.map +1 -1
- package/dist/municipal/streets/streets.getters.js +19 -9
- package/dist/municipal/streets/streets.getters.js.map +1 -1
- package/dist/municipal/streets/streets.types.d.ts +1 -1
- package/dist/municipal/systemInstructions/index.d.ts +3 -3
- package/dist/municipal/systemInstructions/index.d.ts.map +1 -1
- package/dist/municipal/systemInstructions/instructions.getters.d.ts +3 -3
- package/dist/municipal/systemInstructions/instructions.getters.d.ts.map +1 -1
- package/dist/municipal/systemInstructions/instructions.getters.js +10 -4
- package/dist/municipal/systemInstructions/instructions.getters.js.map +1 -1
- package/dist/municipal/systemInstructions/instructions.setters.d.ts +2 -2
- package/dist/municipal/systemInstructions/instructions.setters.d.ts.map +1 -1
- package/dist/municipal/systemInstructions/instructions.setters.js +13 -8
- package/dist/municipal/systemInstructions/instructions.setters.js.map +1 -1
- package/dist/municipal/systemInstructions/instructions.types.d.ts +3 -3
- package/dist/municipal/systemInstructions/instructions.types.d.ts.map +1 -1
- package/dist/municipal/systemInstructions/instructions.types.js +6 -6
- package/dist/municipal/tickets/index.d.ts +2 -2
- package/dist/municipal/tickets/tickets.getters.d.ts +3 -3
- package/dist/municipal/tickets/tickets.getters.d.ts.map +1 -1
- package/dist/municipal/tickets/tickets.getters.js +50 -29
- package/dist/municipal/tickets/tickets.getters.js.map +1 -1
- package/dist/municipal/tickets/tickets.types.d.ts +1 -1
- package/dist/municipal/tickets/tickets.types.d.ts.map +1 -1
- package/dist/municipal/utils/types.d.ts +1 -1
- package/dist/municipal/utils/types.d.ts.map +1 -1
- package/dist/talkpilot/agents/agents.getters.d.ts +1 -1
- package/dist/talkpilot/agents/agents.getters.js +2 -2
- package/dist/talkpilot/agents/agents.types.d.ts +2 -2
- package/dist/talkpilot/agents/index.d.ts +2 -2
- package/dist/talkpilot/backgroundToolResults/backgroundToolResults.getters.d.ts +2 -2
- package/dist/talkpilot/backgroundToolResults/backgroundToolResults.getters.d.ts.map +1 -1
- package/dist/talkpilot/backgroundToolResults/backgroundToolResults.getters.js +1 -1
- package/dist/talkpilot/backgroundToolResults/backgroundToolResults.getters.js.map +1 -1
- package/dist/talkpilot/backgroundToolResults/backgroundToolResults.types.d.ts +2 -2
- package/dist/talkpilot/backgroundToolResults/index.d.ts +2 -2
- package/dist/talkpilot/calls/calls.getters.d.ts +4 -3
- package/dist/talkpilot/calls/calls.getters.d.ts.map +1 -1
- package/dist/talkpilot/calls/calls.getters.js +24 -16
- package/dist/talkpilot/calls/calls.getters.js.map +1 -1
- package/dist/talkpilot/calls/calls.types.d.ts +26 -3
- package/dist/talkpilot/calls/calls.types.d.ts.map +1 -1
- package/dist/talkpilot/calls/calls.types.js +2 -2
- package/dist/talkpilot/calls/index.d.ts +2 -2
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.d.ts +2 -2
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.d.ts.map +1 -1
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.js +2 -2
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.js.map +1 -1
- package/dist/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.d.ts +2 -2
- package/dist/talkpilot/clientAudioBuffers/index.d.ts +2 -2
- package/dist/talkpilot/clients/clients.getters.d.ts +2 -2
- package/dist/talkpilot/clients/clients.getters.d.ts.map +1 -1
- package/dist/talkpilot/clients/clients.getters.js +5 -2
- package/dist/talkpilot/clients/clients.getters.js.map +1 -1
- package/dist/talkpilot/clients/clients.types.d.ts +1 -1
- package/dist/talkpilot/clients/index.d.ts +2 -2
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts +2 -2
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts +3 -3
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts.map +1 -1
- package/dist/talkpilot/clientsConfig/index.d.ts +2 -2
- package/dist/talkpilot/flows/flows.getter.d.ts +2 -2
- package/dist/talkpilot/flows/flows.getter.d.ts.map +1 -1
- package/dist/talkpilot/flows/flows.getter.js +1 -1
- package/dist/talkpilot/flows/flows.getter.js.map +1 -1
- package/dist/talkpilot/flows/flows.schema.d.ts +0 -3
- package/dist/talkpilot/flows/flows.schema.d.ts.map +1 -1
- package/dist/talkpilot/flows/flows.schema.js +87 -80
- package/dist/talkpilot/flows/flows.schema.js.map +1 -1
- package/dist/talkpilot/flows/flows.types.d.ts +16 -17
- package/dist/talkpilot/flows/flows.types.d.ts.map +1 -1
- package/dist/talkpilot/flows/index.d.ts +2 -2
- package/dist/talkpilot/groups/groups.getters.d.ts +2 -2
- package/dist/talkpilot/groups/groups.getters.d.ts.map +1 -1
- package/dist/talkpilot/groups/groups.getters.js +2 -2
- package/dist/talkpilot/groups/groups.getters.js.map +1 -1
- package/dist/talkpilot/groups/groups.types.d.ts +1 -1
- package/dist/talkpilot/groups/index.d.ts +3 -3
- package/dist/talkpilot/groups/phone.utils.d.ts +1 -1
- package/dist/talkpilot/groups/phone.utils.d.ts.map +1 -1
- package/dist/talkpilot/groups/phone.utils.js +2 -2
- package/dist/talkpilot/groups/phone.utils.js.map +1 -1
- package/dist/talkpilot/index.d.ts +16 -16
- package/dist/talkpilot/index.js +1 -1
- package/dist/talkpilot/leads/index.d.ts +2 -2
- package/dist/talkpilot/leads/leads.getter.d.ts +2 -2
- package/dist/talkpilot/leads/leads.getter.d.ts.map +1 -1
- package/dist/talkpilot/leads/leads.getter.js +1 -1
- package/dist/talkpilot/leads/leads.getter.js.map +1 -1
- package/dist/talkpilot/leads/leads.schema.js +16 -16
- package/dist/talkpilot/leads/leads.types.d.ts +1 -1
- package/dist/talkpilot/mongodb-client.d.ts +1 -1
- package/dist/talkpilot/mongodb-client.js +8 -9
- package/dist/talkpilot/mongodb-client.js.map +1 -1
- package/dist/talkpilot/phone_numbers/index.d.ts +1 -1
- package/dist/talkpilot/phone_numbers/index.d.ts.map +1 -1
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts +5 -2
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts.map +1 -1
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.js +66 -12
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.js.map +1 -1
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.d.ts +11 -2
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.d.ts.map +1 -1
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.js +5 -2
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.js.map +1 -1
- package/dist/talkpilot/phone_numbers/phone_numbers.types.d.ts +16 -3
- package/dist/talkpilot/phone_numbers/phone_numbers.types.d.ts.map +1 -1
- package/dist/talkpilot/plans/index.d.ts +2 -2
- package/dist/talkpilot/plans/plans.getters.d.ts +2 -2
- package/dist/talkpilot/plans/plans.getters.d.ts.map +1 -1
- package/dist/talkpilot/plans/plans.getters.js +3 -3
- package/dist/talkpilot/plans/plans.getters.js.map +1 -1
- package/dist/talkpilot/plans/plans.types.d.ts +4 -4
- package/dist/talkpilot/plans/plans.types.d.ts.map +1 -1
- package/dist/talkpilot/plans/plans.types.js +19 -19
- package/dist/talkpilot/results/index.d.ts +2 -2
- package/dist/talkpilot/results/index.d.ts.map +1 -1
- package/dist/talkpilot/results/index.js.map +1 -1
- package/dist/talkpilot/results/results.getter.d.ts +3 -3
- package/dist/talkpilot/results/results.getter.d.ts.map +1 -1
- package/dist/talkpilot/results/results.getter.js +4 -4
- package/dist/talkpilot/results/results.getter.js.map +1 -1
- package/dist/talkpilot/results/results.schema.js +18 -18
- package/dist/talkpilot/results/results.types.d.ts +1 -1
- package/dist/talkpilot/sessions/index.d.ts +2 -2
- package/dist/talkpilot/sessions/sessions.getter.d.ts +3 -3
- package/dist/talkpilot/sessions/sessions.getter.d.ts.map +1 -1
- package/dist/talkpilot/sessions/sessions.getter.js +13 -10
- package/dist/talkpilot/sessions/sessions.getter.js.map +1 -1
- package/dist/talkpilot/sessions/sessions.schema.js +17 -17
- package/dist/talkpilot/sessions/sessions.types.d.ts +2 -2
- package/dist/talkpilot/subscriptions/index.d.ts +3 -3
- package/dist/talkpilot/subscriptions/subscriptions.getters.d.ts +2 -2
- package/dist/talkpilot/subscriptions/subscriptions.getters.d.ts.map +1 -1
- package/dist/talkpilot/subscriptions/subscriptions.getters.js +11 -11
- package/dist/talkpilot/subscriptions/subscriptions.getters.js.map +1 -1
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.d.ts +2 -2
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.d.ts.map +1 -1
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.js.map +1 -1
- package/dist/talkpilot/subscriptions/subscriptions.types.d.ts +2 -2
- package/dist/talkpilot/subscriptions/subscriptions.types.d.ts.map +1 -1
- package/dist/talkpilot/subscriptions/subscriptions.types.js +7 -7
- package/dist/talkpilot/utils/query.utils.d.ts +1 -1
- package/dist/test-utils/db-utils.d.ts +1 -1
- package/dist/test-utils/db-utils.js +2 -2
- package/dist/test-utils/factories/index.d.ts +12 -12
- package/dist/test-utils/factories/municipal/cities.d.ts +2 -2
- package/dist/test-utils/factories/municipal/cities.d.ts.map +1 -1
- package/dist/test-utils/factories/municipal/cities.js +1 -1
- package/dist/test-utils/factories/municipal/departmentsSubjects.d.ts +2 -2
- package/dist/test-utils/factories/municipal/departmentsSubjects.d.ts.map +1 -1
- package/dist/test-utils/factories/municipal/departmentsSubjects.js +7 -1
- package/dist/test-utils/factories/municipal/departmentsSubjects.js.map +1 -1
- package/dist/test-utils/factories/municipal/streets.d.ts +2 -2
- package/dist/test-utils/factories/municipal/streets.d.ts.map +1 -1
- package/dist/test-utils/factories/municipal/streets.js +6 -1
- package/dist/test-utils/factories/municipal/streets.js.map +1 -1
- package/dist/test-utils/factories/municipal/tickets.d.ts +2 -2
- package/dist/test-utils/factories/municipal/tickets.d.ts.map +1 -1
- package/dist/test-utils/factories/municipal/tickets.js +7 -1
- package/dist/test-utils/factories/municipal/tickets.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/agents.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/agents.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/agents.js +4 -4
- package/dist/test-utils/factories/talkpilot/calls.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/calls.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/calls.js +1 -1
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.js +1 -1
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/clientsConfig.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/clientsConfig.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/clientsConfig.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/flows.d.ts +3 -3
- package/dist/test-utils/factories/talkpilot/flows.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/flows.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/groups.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/groups.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/groups.js +9 -9
- package/dist/test-utils/factories/talkpilot/groups.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/phone_numbers.d.ts +3 -3
- package/dist/test-utils/factories/talkpilot/phone_numbers.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/phone_numbers.js.map +1 -1
- package/dist/test-utils/factories/talkpilot/sessions.d.ts +2 -2
- package/dist/test-utils/factories/talkpilot/sessions.d.ts.map +1 -1
- package/dist/test-utils/factories/talkpilot/sessions.js +1 -1
- package/dist/utils/validation.js +2 -2
- package/dist/utils/validation.js.map +1 -1
- package/package.json +3 -1
- package/src/__tests__/setup.ts +3 -3
- package/src/connection.ts +27 -25
- package/src/index.ts +9 -9
- package/src/municipal/__tests__/validation.spec.ts +35 -23
- package/src/municipal/cities/cities.getters.ts +16 -10
- package/src/municipal/cities/cities.types.ts +1 -1
- package/src/municipal/cities/index.ts +2 -2
- package/src/municipal/departmentsSubjects/departmentsSubjects.getters.ts +53 -44
- package/src/municipal/departmentsSubjects/departmentsSubjects.types.ts +5 -5
- package/src/municipal/departmentsSubjects/index.ts +2 -3
- package/src/municipal/index.ts +10 -10
- package/src/municipal/mongodb-client.ts +13 -10
- package/src/municipal/streets/index.ts +2 -2
- package/src/municipal/streets/streets.getters.ts +43 -23
- package/src/municipal/streets/streets.types.ts +1 -1
- package/src/municipal/systemInstructions/__tests__/getters.spec.ts +67 -52
- package/src/municipal/systemInstructions/__tests__/setters.spec.ts +271 -238
- package/src/municipal/systemInstructions/index.ts +7 -3
- package/src/municipal/systemInstructions/instructions.getters.ts +30 -18
- package/src/municipal/systemInstructions/instructions.setters.ts +43 -19
- package/src/municipal/systemInstructions/instructions.types.ts +10 -10
- package/src/municipal/tickets/__tests__/tickets.getters.spec.ts +12 -12
- package/src/municipal/tickets/index.ts +2 -2
- package/src/municipal/tickets/tickets.getters.ts +69 -42
- package/src/municipal/tickets/tickets.types.ts +2 -2
- package/src/municipal/utils/types.ts +8 -3
- package/src/talkpilot/__tests__/db.spec.ts +12 -12
- package/src/talkpilot/__tests__/mongodb-client.spec.ts +7 -8
- package/src/talkpilot/__tests__/validation.spec.ts +30 -24
- package/src/talkpilot/agents/__tests__/agents.getters.spec.ts +10 -10
- package/src/talkpilot/agents/agents.getters.ts +3 -3
- package/src/talkpilot/agents/agents.types.ts +2 -2
- package/src/talkpilot/agents/index.ts +2 -2
- package/src/talkpilot/backgroundToolResults/__tests__/backgroundToolResults.getters.spec.ts +42 -31
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.getters.ts +11 -11
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.types.ts +2 -3
- package/src/talkpilot/backgroundToolResults/index.ts +2 -2
- package/src/talkpilot/calls/__tests__/callStats.utils.spec.ts +27 -27
- package/src/talkpilot/calls/__tests__/calls.spec.ts +178 -40
- package/src/talkpilot/calls/calls.getters.ts +57 -27
- package/src/talkpilot/calls/calls.types.ts +39 -16
- package/src/talkpilot/calls/index.ts +2 -2
- package/src/talkpilot/clientAudioBuffers/__tests__/clientAudioBuffer.getters.spec.ts +73 -39
- package/src/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.ts +18 -11
- package/src/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.ts +2 -2
- package/src/talkpilot/clientAudioBuffers/index.ts +2 -2
- package/src/talkpilot/clients/clients.getters.ts +10 -5
- package/src/talkpilot/clients/clients.types.ts +1 -1
- package/src/talkpilot/clients/index.ts +2 -2
- package/src/talkpilot/clientsConfig/__tests__/clientsConfig.spec.ts +21 -18
- package/src/talkpilot/clientsConfig/clientsConfig.getters.ts +6 -4
- package/src/talkpilot/clientsConfig/clientsConfig.types.ts +10 -8
- package/src/talkpilot/clientsConfig/index.ts +2 -2
- package/src/talkpilot/flows/__tests__/flows.schema.spec.ts +38 -37
- package/src/talkpilot/flows/flows.getter.ts +8 -5
- package/src/talkpilot/flows/flows.schema.ts +87 -80
- package/src/talkpilot/flows/flows.types.ts +23 -24
- package/src/talkpilot/flows/index.ts +2 -2
- package/src/talkpilot/groups/__tests__/groups.spec.ts +34 -27
- package/src/talkpilot/groups/__tests__/phone.utils.spec.ts +20 -20
- package/src/talkpilot/groups/groups.getters.ts +8 -5
- package/src/talkpilot/groups/groups.types.ts +1 -1
- package/src/talkpilot/groups/index.ts +3 -3
- package/src/talkpilot/groups/phone.utils.ts +12 -6
- package/src/talkpilot/index.ts +17 -17
- package/src/talkpilot/leads/index.ts +2 -2
- package/src/talkpilot/leads/leads.getter.ts +5 -4
- package/src/talkpilot/leads/leads.schema.ts +16 -16
- package/src/talkpilot/leads/leads.types.ts +1 -1
- package/src/talkpilot/mongodb-client.ts +12 -12
- package/src/talkpilot/phone_numbers/__tests__/phone_numbers.spec.ts +162 -33
- package/src/talkpilot/phone_numbers/index.ts +1 -1
- package/src/talkpilot/phone_numbers/phone_numbers.getter.ts +94 -18
- package/src/talkpilot/phone_numbers/phone_numbers.schema.ts +5 -2
- package/src/talkpilot/phone_numbers/phone_numbers.types.ts +18 -3
- package/src/talkpilot/plans/__tests__/plans.spec.ts +30 -26
- package/src/talkpilot/plans/index.ts +2 -2
- package/src/talkpilot/plans/plans.getters.ts +25 -18
- package/src/talkpilot/plans/plans.types.ts +27 -23
- package/src/talkpilot/results/index.ts +5 -2
- package/src/talkpilot/results/results.getter.ts +9 -8
- package/src/talkpilot/results/results.schema.ts +18 -18
- package/src/talkpilot/results/results.types.ts +1 -1
- package/src/talkpilot/sessions/__tests__/sessions.spec.ts +65 -41
- package/src/talkpilot/sessions/index.ts +2 -2
- package/src/talkpilot/sessions/sessions.getter.ts +21 -16
- package/src/talkpilot/sessions/sessions.schema.ts +17 -17
- package/src/talkpilot/sessions/sessions.types.ts +2 -2
- package/src/talkpilot/subscriptions/__tests__/subscriptions.getters.utils.spec.ts +18 -15
- package/src/talkpilot/subscriptions/index.ts +3 -3
- package/src/talkpilot/subscriptions/subscriptions.getters.ts +36 -33
- package/src/talkpilot/subscriptions/subscriptions.getters.utils.ts +10 -3
- package/src/talkpilot/subscriptions/subscriptions.types.ts +9 -9
- package/src/talkpilot/utils/__tests__/query.utils.spec.ts +8 -8
- package/src/talkpilot/utils/query.utils.ts +2 -2
- package/src/test-utils/db-utils.ts +5 -5
- package/src/test-utils/factories/index.ts +12 -12
- package/src/test-utils/factories/municipal/cities.ts +5 -5
- package/src/test-utils/factories/municipal/departmentsSubjects.ts +32 -25
- package/src/test-utils/factories/municipal/streets.ts +10 -5
- package/src/test-utils/factories/municipal/tickets.ts +12 -6
- package/src/test-utils/factories/talkpilot/agents.ts +8 -8
- package/src/test-utils/factories/talkpilot/calls.ts +5 -5
- package/src/test-utils/factories/talkpilot/clientAudioBuffers.ts +14 -12
- package/src/test-utils/factories/talkpilot/clientsConfig.ts +7 -8
- package/src/test-utils/factories/talkpilot/flows.ts +7 -5
- package/src/test-utils/factories/talkpilot/groups.ts +13 -13
- package/src/test-utils/factories/talkpilot/phone_numbers.ts +8 -6
- package/src/test-utils/factories/talkpilot/sessions.ts +5 -5
- package/src/utils/validation.ts +4 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tickets.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/municipal/tickets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"tickets.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/municipal/tickets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAWjD,eAAO,MAAM,aAAa,2EAoBvB,CAAC;AAEJ,wBAAgB,YAAY,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAEhE"}
|
|
@@ -5,7 +5,13 @@ exports.createTicket = createTicket;
|
|
|
5
5
|
const fishery_1 = require("fishery");
|
|
6
6
|
const mongodb_1 = require("mongodb");
|
|
7
7
|
const faker_1 = require("@faker-js/faker");
|
|
8
|
-
const VALID_CITIES = [
|
|
8
|
+
const VALID_CITIES = [
|
|
9
|
+
"ashdod",
|
|
10
|
+
"maltar",
|
|
11
|
+
"billit",
|
|
12
|
+
"hashkelon",
|
|
13
|
+
"tests",
|
|
14
|
+
];
|
|
9
15
|
exports.ticketFactory = fishery_1.Factory.define(() => ({
|
|
10
16
|
_id: new mongodb_1.ObjectId(),
|
|
11
17
|
createdAt: new Date(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tickets.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/municipal/tickets.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"tickets.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/municipal/tickets.ts"],"names":[],"mappings":";;;AAoCA,oCAEC;AAtCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAIxC,MAAM,YAAY,GAAe;IAC/B,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,WAAW;IACX,OAAO;CACR,CAAC;AAEW,QAAA,aAAa,GAAG,iBAAO,CAAC,MAAM,CAAS,GAAG,EAAE,CAAC,CAAC;IACzD,GAAG,EAAE,IAAI,kBAAQ,EAAE;IACnB,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,QAAQ,EAAE,aAAK,CAAC,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC;IAClD,kBAAkB,EAAE;QAClB,UAAU,EAAE,aAAK,CAAC,MAAM,CAAC,SAAS,EAAE;QACpC,SAAS,EAAE,aAAK,CAAC,MAAM,CAAC,QAAQ,EAAE;QAClC,iBAAiB,EAAE,aAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;QACzC,MAAM,EAAE,aAAK,CAAC,QAAQ,CAAC,MAAM,EAAE;QAC/B,YAAY,EAAE,aAAK,CAAC,QAAQ,CAAC,cAAc,EAAE;QAC7C,gBAAgB,EAAE,aAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QACzC,oBAAoB,EAAE,aAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QAC7C,MAAM,EAAE,aAAK,CAAC,KAAK,CAAC,GAAG,EAAE;QACzB,MAAM,EAAE,aAAK,CAAC,KAAK,CAAC,GAAG,EAAE;QACzB,MAAM,EAAE,aAAK,CAAC,KAAK,CAAC,GAAG,EAAE;QACzB,KAAK,EAAE,aAAK,CAAC,MAAM,CAAC,QAAQ,EAAE;QAC9B,KAAK,EAAE,aAAK,CAAC,MAAM,CAAC,QAAQ,EAAE;QAC9B,KAAK,EAAE,aAAK,CAAC,MAAM,CAAC,QAAQ,EAAE;KAC/B;CACF,CAAC,CAAC,CAAC;AAEJ,SAAgB,YAAY,CAAC,SAA2B;IACtD,OAAO,qBAAa,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import type { Agent } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import type { Agent } from "../../../talkpilot";
|
|
3
3
|
export declare const agentFactory: Factory<Agent, any, Agent, import("fishery").DeepPartialObject<Agent>>;
|
|
4
4
|
export declare function createAgent(overrides?: Partial<Agent>): Agent;
|
|
5
5
|
//# sourceMappingURL=agents.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agents.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/agents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"agents.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/agents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAEhD,eAAO,MAAM,YAAY,wEAStB,CAAC;AAEJ,wBAAgB,WAAW,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,CAE7D"}
|
|
@@ -7,13 +7,13 @@ const mongodb_1 = require("mongodb");
|
|
|
7
7
|
const faker_1 = require("@faker-js/faker");
|
|
8
8
|
exports.agentFactory = fishery_1.Factory.define(() => ({
|
|
9
9
|
name: faker_1.faker.person.fullName(),
|
|
10
|
-
language:
|
|
11
|
-
voice:
|
|
10
|
+
language: "en",
|
|
11
|
+
voice: "alloy",
|
|
12
12
|
instructions: faker_1.faker.lorem.paragraph(),
|
|
13
13
|
labels: [],
|
|
14
14
|
clientId: new mongodb_1.ObjectId().toString(),
|
|
15
|
-
role:
|
|
16
|
-
gender: faker_1.faker.helpers.arrayElement([
|
|
15
|
+
role: "assistant",
|
|
16
|
+
gender: faker_1.faker.helpers.arrayElement(["male", "female"]),
|
|
17
17
|
}));
|
|
18
18
|
function createAgent(overrides) {
|
|
19
19
|
return exports.agentFactory.build(overrides);
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import type { Call } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import type { Call } from "../../../talkpilot";
|
|
3
3
|
export declare const callFactory: Factory<Call, any, Call, import("fishery").DeepPartialObject<Call>>;
|
|
4
4
|
export declare function createOutGoingCallDoc(overrides?: Partial<Call>): Call;
|
|
5
5
|
export declare function createIncomingCallDoc(overrides?: Partial<Call>): Call;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"calls.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/calls.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"calls.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/calls.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAE/C,eAAO,MAAM,WAAW,qEAcrB,CAAC;AAEJ,wBAAgB,qBAAqB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAMrE;AAED,wBAAgB,qBAAqB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAOrE"}
|
|
@@ -17,7 +17,7 @@ exports.callFactory = fishery_1.Factory.define(() => ({
|
|
|
17
17
|
isIncomingCall: false,
|
|
18
18
|
isOutgoingCall: true,
|
|
19
19
|
callLength: faker_1.faker.number.int({ min: 0, max: 3600 }),
|
|
20
|
-
env:
|
|
20
|
+
env: "test",
|
|
21
21
|
updatedAt: new Date(),
|
|
22
22
|
createdAt: new Date(),
|
|
23
23
|
}));
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import { CreateAudioBufferInput } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { CreateAudioBufferInput } from "../../../talkpilot";
|
|
3
3
|
export declare const audioBufferInputFactory: Factory<CreateAudioBufferInput, any, CreateAudioBufferInput, import("fishery").DeepPartialObject<CreateAudioBufferInput>>;
|
|
4
4
|
export declare function createAudioBufferInput(overrides?: Partial<CreateAudioBufferInput>): CreateAudioBufferInput;
|
|
5
5
|
//# sourceMappingURL=clientAudioBuffers.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clientAudioBuffers.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientAudioBuffers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,sBAAsB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"clientAudioBuffers.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientAudioBuffers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAE5D,eAAO,MAAM,uBAAuB,2HASnC,CAAC;AAEF,wBAAgB,sBAAsB,CACpC,SAAS,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC,GAC1C,sBAAsB,CAExB"}
|
|
@@ -5,7 +5,7 @@ exports.createAudioBufferInput = createAudioBufferInput;
|
|
|
5
5
|
const fishery_1 = require("fishery");
|
|
6
6
|
const faker_1 = require("@faker-js/faker");
|
|
7
7
|
exports.audioBufferInputFactory = fishery_1.Factory.define(() => ({
|
|
8
|
-
callSid:
|
|
8
|
+
callSid: "CA1234567890abcdef1234567890abcdef",
|
|
9
9
|
clientId: faker_1.faker.string.uuid(),
|
|
10
10
|
bucketStartMs: faker_1.faker.number.int({ min: 0, max: 1000000 }),
|
|
11
11
|
bucketDurationMs: faker_1.faker.helpers.arrayElement([500, 1000]),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clientAudioBuffers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientAudioBuffers.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"clientAudioBuffers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientAudioBuffers.ts"],"names":[],"mappings":";;;AAeA,wDAIC;AAnBD,qCAAkC;AAClC,2CAAwC;AAG3B,QAAA,uBAAuB,GAAG,iBAAO,CAAC,MAAM,CACnD,GAAG,EAAE,CAAC,CAAC;IACL,OAAO,EAAE,oCAAoC;IAC7C,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC7B,aAAa,EAAE,aAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;IACzD,gBAAgB,EAAE,aAAK,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,aAAK,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7D,KAAK,EAAE,aAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;CACrD,CAAC,CACH,CAAC;AAEF,SAAgB,sBAAsB,CACpC,SAA2C;IAE3C,OAAO,+BAAuB,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;AACxD,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import type { ClientConfig, ClientConfigDoc } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import type { ClientConfig, ClientConfigDoc } from "../../../talkpilot";
|
|
3
3
|
export declare const clientConfigFactory: Factory<ClientConfigDoc, any, ClientConfigDoc, import("fishery").DeepPartialObject<ClientConfigDoc>>;
|
|
4
4
|
export declare function createClientConfig(overrides?: Partial<ClientConfig>): ClientConfigDoc;
|
|
5
5
|
//# sourceMappingURL=clientsConfig.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clientsConfig.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientsConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"clientsConfig.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientsConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAExE,eAAO,MAAM,mBAAmB,sGAI7B,CAAC;AAEJ,wBAAgB,kBAAkB,CAChC,SAAS,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAChC,eAAe,CAIjB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clientsConfig.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientsConfig.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"clientsConfig.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientsConfig.ts"],"names":[],"mappings":";;;AAWA,gDAMC;AAjBD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,mBAAmB,GAAG,iBAAO,CAAC,MAAM,CAAkB,GAAG,EAAE,CAAC,CAAC;IACxE,GAAG,EAAE,IAAI,kBAAQ,EAAE;IACnB,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC7B,QAAQ,EAAE,EAAE;CACb,CAAC,CAAC,CAAC;AAEJ,SAAgB,kBAAkB,CAChC,SAAiC;IAEjC,OAAO,2BAAmB,CAAC,KAAK,CAAC;QAC/B,GAAG,SAAS;KACb,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import { ObjectId } from
|
|
3
|
-
import type { Flow } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import type { Flow } from "../../../talkpilot";
|
|
4
4
|
export declare const flowFactory: Factory<Flow & {
|
|
5
5
|
_id: ObjectId;
|
|
6
6
|
}, any, Flow & {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"flows.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/flows.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"flows.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/flows.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAE/C,eAAO,MAAM,WAAW;SAAgC,QAAQ;;SAAR,QAAQ;;SAAR,QAAQ;GAa9D,CAAC;AAEH,wBAAgB,UAAU,CACxB,SAAS,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,GACxB,IAAI,GAAG;IAAE,GAAG,EAAE,QAAQ,CAAA;CAAE,CAU1B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"flows.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/flows.ts"],"names":[],"mappings":";;;AAoBA,
|
|
1
|
+
{"version":3,"file":"flows.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/flows.ts"],"names":[],"mappings":";;;AAoBA,gCAYC;AAhCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,WAAW,GAAG,iBAAO,CAAC,MAAM,CAA2B,GAAG,EAAE;IACvE,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,OAAO;QACL,GAAG,EAAE,IAAI,kBAAQ,EAAE;QACnB,QAAQ,EAAE,aAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC9B,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;QAC7B,kBAAkB,EAAE,aAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5C,eAAe,EAAE,aAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;QACvC,QAAQ,EAAE,EAAE;QACZ,YAAY,EAAE,EAAE;QAChB,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,GAAG;KACf,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,SAAgB,UAAU,CACxB,SAAyB;IAEzB,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,IAAI,GAAG,mBAAW,CAAC,KAAK,EAAE,CAAC;IACjC,OAAO;QACL,GAAG,IAAI;QACP,GAAG,SAAS;QACZ,GAAG,EAAG,SAAS,EAAE,GAAgB,IAAI,IAAI,CAAC,GAAG;QAC7C,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,SAAS,EAAE,SAAS,IAAI,GAAG;KACvC,CAAC;AACJ,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import type { Group, GroupContact, GroupDoc } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import type { Group, GroupContact, GroupDoc } from "../../../talkpilot";
|
|
3
3
|
export declare const groupContactFactory: Factory<GroupContact, any, GroupContact, import("fishery").DeepPartialObject<GroupContact>>;
|
|
4
4
|
export declare const groupFactory: Factory<GroupDoc, any, GroupDoc, import("fishery").DeepPartialObject<GroupDoc>>;
|
|
5
5
|
export declare function createGroup(overrides?: Partial<Group>): GroupDoc;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"groups.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/groups.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"groups.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/groups.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAExE,eAAO,MAAM,mBAAmB,6FAa7B,CAAC;AAEJ,eAAO,MAAM,YAAY,iFAQtB,CAAC;AAEJ,wBAAgB,WAAW,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,QAAQ,CAEhE"}
|
|
@@ -8,16 +8,16 @@ const faker_1 = require("@faker-js/faker");
|
|
|
8
8
|
exports.groupContactFactory = fishery_1.Factory.define(() => ({
|
|
9
9
|
name: faker_1.faker.person.firstName(),
|
|
10
10
|
phone: {
|
|
11
|
-
national:
|
|
12
|
-
національний:
|
|
13
|
-
nacionales:
|
|
14
|
-
национальные:
|
|
15
|
-
e164:
|
|
16
|
-
region:
|
|
17
|
-
countryCallingCode:
|
|
18
|
-
formatted:
|
|
11
|
+
national: "500000000",
|
|
12
|
+
національний: "500000000",
|
|
13
|
+
nacionales: "500000000",
|
|
14
|
+
национальные: "500000000",
|
|
15
|
+
e164: "+972500000000",
|
|
16
|
+
region: "IL",
|
|
17
|
+
countryCallingCode: "972",
|
|
18
|
+
formatted: "+972 50-000-0000",
|
|
19
19
|
},
|
|
20
|
-
gender: faker_1.faker.helpers.arrayElement([
|
|
20
|
+
gender: faker_1.faker.helpers.arrayElement(["male", "female"]),
|
|
21
21
|
}));
|
|
22
22
|
exports.groupFactory = fishery_1.Factory.define(() => ({
|
|
23
23
|
_id: new mongodb_1.ObjectId(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"groups.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/groups.ts"],"names":[],"mappings":";;;AA8BA,kCAEC;AAhCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,mBAAmB,GAAG,iBAAO,CAAC,MAAM,CAAe,GAAG,EAAE,CAAC,CAAC;IACrE,IAAI,EAAE,aAAK,CAAC,MAAM,CAAC,SAAS,EAAE;IAC9B,KAAK,EAAE;QACL,QAAQ,EAAE,WAAW;
|
|
1
|
+
{"version":3,"file":"groups.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/groups.ts"],"names":[],"mappings":";;;AA8BA,kCAEC;AAhCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,mBAAmB,GAAG,iBAAO,CAAC,MAAM,CAAe,GAAG,EAAE,CAAC,CAAC;IACrE,IAAI,EAAE,aAAK,CAAC,MAAM,CAAC,SAAS,EAAE;IAC9B,KAAK,EAAE;QACL,QAAQ,EAAE,WAAW;QACrB,YAAY,EAAE,WAAW;QACzB,UAAU,EAAE,WAAW;QACvB,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,eAAwB;QAC9B,MAAM,EAAE,IAAI;QACZ,kBAAkB,EAAE,KAAK;QACzB,SAAS,EAAE,kBAAkB;KAC9B;IACD,MAAM,EAAE,aAAK,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;CACvD,CAAC,CAAC,CAAC;AAES,QAAA,YAAY,GAAG,iBAAO,CAAC,MAAM,CAAW,GAAG,EAAE,CAAC,CAAC;IAC1D,GAAG,EAAE,IAAI,kBAAQ,EAAE;IACnB,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC7B,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,IAAI,EAAE,aAAK,CAAC,OAAO,CAAC,IAAI,EAAE;IAC1B,WAAW,EAAE,aAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;IACnC,QAAQ,EAAE,2BAAmB,CAAC,SAAS,CAAC,CAAC,CAAC;CAC3C,CAAC,CAAC,CAAC;AAEJ,SAAgB,WAAW,CAAC,SAA0B;IACpD,OAAO,oBAAY,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;AACvC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import { ObjectId } from
|
|
3
|
-
import type { PhoneNumber } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import type { PhoneNumber } from "../../../talkpilot";
|
|
4
4
|
export declare const phoneNumberFactory: Factory<PhoneNumber & {
|
|
5
5
|
_id?: ObjectId;
|
|
6
6
|
}, any, PhoneNumber & {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"phone_numbers.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/phone_numbers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"phone_numbers.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/phone_numbers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEtD,eAAO,MAAM,kBAAkB;UACP,QAAQ;;UAAR,QAAQ;;UAAR,QAAQ;GAS7B,CAAC;AAEJ,wBAAgB,iBAAiB,CAC/B,SAAS,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG;IAAE,OAAO,CAAC,EAAE,QAAQ,CAAA;CAAE,GACxD,WAAW,GAAG;IAAE,GAAG,CAAC,EAAE,QAAQ,CAAA;CAAE,CAElC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"phone_numbers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/phone_numbers.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"phone_numbers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/phone_numbers.ts"],"names":[],"mappings":";;;AAiBA,8CAIC;AArBD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,kBAAkB,GAAG,iBAAO,CAAC,MAAM,CAE9C,GAAG,EAAE,CAAC,CAAC;IACP,GAAG,EAAE,IAAI,kBAAQ,EAAE;IACnB,SAAS,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC9B,OAAO,EAAE,IAAI,kBAAQ,EAAE;IACvB,YAAY,EAAE,aAAK,CAAC,KAAK,CAAC,MAAM,EAAE;IAClC,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,UAAU,EAAE,IAAI;CACjB,CAAC,CAAC,CAAC;AAEJ,SAAgB,iBAAiB,CAC/B,SAAyD;IAEzD,OAAO,0BAAkB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;AAC7C,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Factory } from
|
|
2
|
-
import type { Session } from
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import type { Session } from "../../../talkpilot";
|
|
3
3
|
export declare const sessionFactory: Factory<Session, any, Session, import("fishery").DeepPartialObject<Session>>;
|
|
4
4
|
export declare function createSession(overrides?: Partial<Session>): Session;
|
|
5
5
|
//# sourceMappingURL=sessions.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAElD,eAAO,MAAM,cAAc,8EAkBxB,CAAC;AAEJ,wBAAgB,aAAa,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CASnE"}
|
package/dist/utils/validation.js
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
7
|
exports.validateMongoUri = exports.validateConfig = void 0;
|
|
8
8
|
const validateConfig = (configName, value) => {
|
|
9
|
-
if (!value || value.trim() ===
|
|
9
|
+
if (!value || value.trim() === "") {
|
|
10
10
|
throw new Error(`[core-db] Configuration Error: '${configName}' is missing. ` +
|
|
11
11
|
`Please provide it via parameters or set the corresponding environment variable.`);
|
|
12
12
|
}
|
|
@@ -14,7 +14,7 @@ const validateConfig = (configName, value) => {
|
|
|
14
14
|
};
|
|
15
15
|
exports.validateConfig = validateConfig;
|
|
16
16
|
const validateMongoUri = (uri) => {
|
|
17
|
-
if (!uri.startsWith(
|
|
17
|
+
if (!uri.startsWith("mongodb://") && !uri.startsWith("mongodb+srv://")) {
|
|
18
18
|
throw new Error(`[core-db] Connection Error: The provided MongoDB URI is invalid. ` +
|
|
19
19
|
`It must start with 'mongodb://' or 'mongodb+srv://'. Received: '${uri}'`);
|
|
20
20
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEI,MAAM,cAAc,GAAG,CAAC,UAAkB,EAAE,KAAc,EAAU,EAAE;IAC3E,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CACb,mCAAmC,UAAU,gBAAgB;
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEI,MAAM,cAAc,GAAG,CAAC,UAAkB,EAAE,KAAc,EAAU,EAAE;IAC3E,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CACb,mCAAmC,UAAU,gBAAgB;YAC3D,iFAAiF,CACpF,CAAC;IACJ,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AARW,QAAA,cAAc,kBAQzB;AAEK,MAAM,gBAAgB,GAAG,CAAC,GAAW,EAAQ,EAAE;IACpD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE,CAAC;QACvE,MAAM,IAAI,KAAK,CACb,mEAAmE;YACjE,mEAAmE,GAAG,GAAG,CAC5E,CAAC;IACJ,CAAC;AACH,CAAC,CAAC;AAPW,QAAA,gBAAgB,oBAO3B"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@talkpilot/core-db",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.10",
|
|
4
4
|
"description": "Core database package for centralized connections and ORM integration.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -9,6 +9,7 @@
|
|
|
9
9
|
"dev": "tsc --watch",
|
|
10
10
|
"test": "jest",
|
|
11
11
|
"lint": "eslint 'src/**/*.{ts,tsx}'",
|
|
12
|
+
"format": "prettier --write \"src/**/*.{ts,tsx}\"",
|
|
12
13
|
"prepare": "npm run build"
|
|
13
14
|
},
|
|
14
15
|
"keywords": [
|
|
@@ -34,6 +35,7 @@
|
|
|
34
35
|
"fishery": "^2.4.0",
|
|
35
36
|
"jest": "^29.0.0",
|
|
36
37
|
"mongodb-memory-server": "^10.0.0",
|
|
38
|
+
"prettier": "^3.8.2",
|
|
37
39
|
"ts-jest": "^29.0.0",
|
|
38
40
|
"typescript": "^5.0.0"
|
|
39
41
|
},
|
package/src/__tests__/setup.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { initTestDb, closeTestDb } from
|
|
1
|
+
import { initTestDb, closeTestDb } from "../test-utils/db-utils";
|
|
2
2
|
|
|
3
3
|
declare global {
|
|
4
4
|
// eslint-disable-next-line no-var
|
|
5
|
-
var db: import(
|
|
5
|
+
var db: import("mongodb").Db;
|
|
6
6
|
}
|
|
7
7
|
|
|
8
8
|
// Set up global mocks if needed
|
|
@@ -17,4 +17,4 @@ afterEach(async () => {
|
|
|
17
17
|
jest.resetAllMocks();
|
|
18
18
|
});
|
|
19
19
|
|
|
20
|
-
process.env.NODE_ENV =
|
|
20
|
+
process.env.NODE_ENV = "test";
|
package/src/connection.ts
CHANGED
|
@@ -1,40 +1,42 @@
|
|
|
1
|
-
import { mongodbClient } from
|
|
2
|
-
import { municipalDataMongodbClient } from
|
|
1
|
+
import { mongodbClient } from "./talkpilot";
|
|
2
|
+
import { municipalDataMongodbClient } from "./municipal";
|
|
3
3
|
|
|
4
4
|
let isConnected = false;
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* Ensures the database clients are initialized.
|
|
8
|
-
* This function reads from
|
|
8
|
+
* This function reads from MONGO_URI.
|
|
9
9
|
*/
|
|
10
10
|
export async function ensureDbConnected() {
|
|
11
11
|
if (isConnected) {
|
|
12
12
|
return;
|
|
13
13
|
}
|
|
14
14
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
15
|
+
const mongoUri = process.env.MONGO_URI || process.env.MONGODB_URI;
|
|
16
|
+
const talkpilotUri = mongoUri;
|
|
17
|
+
const municipalUri = mongoUri;
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
} else {
|
|
30
|
-
const dbName = municipalUri.split('/').pop()?.split('?')[0];
|
|
31
|
-
await municipalDataMongodbClient.connect(municipalUri, dbName);
|
|
32
|
-
console.info(`[core-db] Connected to Municipal Data MongoDB: ${dbName}`);
|
|
33
|
-
}
|
|
19
|
+
if (!talkpilotUri) {
|
|
20
|
+
console.warn("[core-db] MONGO_URI is not set");
|
|
21
|
+
} else {
|
|
22
|
+
const dbNameFromUri = talkpilotUri.split("/").pop()?.split("?")[0];
|
|
23
|
+
const dbName = dbNameFromUri || process.env.TALKPILOT_DB_NAME;
|
|
24
|
+
await mongodbClient.connect(talkpilotUri, dbName);
|
|
25
|
+
console.info(
|
|
26
|
+
`[core-db] Connected to TalkPilot MongoDB: ${dbName || "via env"}`,
|
|
27
|
+
);
|
|
28
|
+
}
|
|
34
29
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
30
|
+
if (!municipalUri) {
|
|
31
|
+
console.warn("[core-db] MONGO_URI is not set");
|
|
32
|
+
} else {
|
|
33
|
+
const dbNameFromUri = municipalUri.split("/").pop()?.split("?")[0];
|
|
34
|
+
const dbName = dbNameFromUri || process.env.MUNICIPAL_DB_NAME;
|
|
35
|
+
await municipalDataMongodbClient.connect(municipalUri, dbName);
|
|
36
|
+
console.info(
|
|
37
|
+
`[core-db] Connected to Municipal Data MongoDB: ${dbName || "via env"}`,
|
|
38
|
+
);
|
|
39
39
|
}
|
|
40
|
+
|
|
41
|
+
isConnected = true;
|
|
40
42
|
}
|
package/src/index.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
// TalkPilot DB exports
|
|
2
|
-
export * from
|
|
3
|
-
export * from
|
|
2
|
+
export * from "./talkpilot";
|
|
3
|
+
export * from "./connection";
|
|
4
4
|
|
|
5
5
|
export {
|
|
6
6
|
municipalDataMongodbClient,
|
|
7
7
|
getDb as getMunicipalDataDb,
|
|
8
8
|
setDb as setMunicipalDataDb,
|
|
9
9
|
ObjectId as MunicipalDataObjectId,
|
|
10
|
-
} from
|
|
11
|
-
export * from
|
|
12
|
-
export * from
|
|
13
|
-
export * from
|
|
14
|
-
export * from
|
|
15
|
-
export * from
|
|
16
|
-
export * from
|
|
10
|
+
} from "./municipal";
|
|
11
|
+
export * from "./municipal/cities";
|
|
12
|
+
export * from "./municipal/streets";
|
|
13
|
+
export * from "./municipal/departmentsSubjects";
|
|
14
|
+
export * from "./municipal/tickets";
|
|
15
|
+
export * from "./municipal/systemInstructions";
|
|
16
|
+
export * from "./municipal/utils/types";
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { municipalDataMongodbClient } from
|
|
2
|
-
import { MongoClient } from
|
|
1
|
+
import { municipalDataMongodbClient } from "../mongodb-client";
|
|
2
|
+
import { MongoClient } from "mongodb";
|
|
3
3
|
|
|
4
|
-
describe(
|
|
4
|
+
describe("MunicipalDataMongoDBClient Validation", () => {
|
|
5
5
|
const originalEnv = process.env;
|
|
6
6
|
|
|
7
7
|
beforeEach(() => {
|
|
8
8
|
process.env = { ...originalEnv };
|
|
9
9
|
delete process.env.MONGO_URI;
|
|
10
10
|
delete process.env.MONGODB_URI;
|
|
11
|
-
|
|
11
|
+
|
|
12
12
|
// Force reset singleton state
|
|
13
13
|
(municipalDataMongodbClient as any).client = null;
|
|
14
14
|
(municipalDataMongodbClient as any).db = null;
|
|
@@ -19,31 +19,43 @@ describe('MunicipalDataMongoDBClient Validation', () => {
|
|
|
19
19
|
await municipalDataMongodbClient.disconnect();
|
|
20
20
|
});
|
|
21
21
|
|
|
22
|
-
it(
|
|
23
|
-
const mockDb = { databaseName:
|
|
24
|
-
const connectSpy = jest
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
const
|
|
22
|
+
it("should succeed with default database name if only URI is provided", async () => {
|
|
23
|
+
const mockDb = { databaseName: "municipal-data" };
|
|
24
|
+
const connectSpy = jest
|
|
25
|
+
.spyOn(MongoClient.prototype, "connect")
|
|
26
|
+
.mockResolvedValue({} as any);
|
|
27
|
+
const dbSpy = jest
|
|
28
|
+
.spyOn(MongoClient.prototype, "db")
|
|
29
|
+
.mockReturnValue(mockDb as any);
|
|
30
|
+
|
|
31
|
+
const validUri = "mongodb://127.0.0.1:27017";
|
|
28
32
|
await municipalDataMongodbClient.connect(validUri);
|
|
29
|
-
|
|
33
|
+
|
|
30
34
|
expect(municipalDataMongodbClient.getDb()).toBeDefined();
|
|
31
|
-
expect(municipalDataMongodbClient.getDb().databaseName).toBe(
|
|
32
|
-
|
|
35
|
+
expect(municipalDataMongodbClient.getDb().databaseName).toBe(
|
|
36
|
+
"municipal-data",
|
|
37
|
+
);
|
|
38
|
+
|
|
33
39
|
connectSpy.mockRestore();
|
|
34
40
|
dbSpy.mockRestore();
|
|
35
41
|
});
|
|
36
42
|
|
|
37
|
-
it(
|
|
38
|
-
const mockDb = { databaseName:
|
|
39
|
-
const connectSpy = jest
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
const
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
43
|
+
it("should allow overriding the default database name", async () => {
|
|
44
|
+
const mockDb = { databaseName: "custom-municipal-db" };
|
|
45
|
+
const connectSpy = jest
|
|
46
|
+
.spyOn(MongoClient.prototype, "connect")
|
|
47
|
+
.mockResolvedValue({} as any);
|
|
48
|
+
const dbSpy = jest
|
|
49
|
+
.spyOn(MongoClient.prototype, "db")
|
|
50
|
+
.mockReturnValue(mockDb as any);
|
|
51
|
+
|
|
52
|
+
const validUri = "mongodb://127.0.0.1:27017";
|
|
53
|
+
await municipalDataMongodbClient.connect(validUri, "custom-municipal-db");
|
|
54
|
+
|
|
55
|
+
expect(municipalDataMongodbClient.getDb().databaseName).toBe(
|
|
56
|
+
"custom-municipal-db",
|
|
57
|
+
);
|
|
58
|
+
|
|
47
59
|
connectSpy.mockRestore();
|
|
48
60
|
dbSpy.mockRestore();
|
|
49
61
|
});
|
|
@@ -1,23 +1,27 @@
|
|
|
1
|
-
import { getDb, ObjectId, City } from
|
|
2
|
-
import { Collection, Filter, ObjectId as MongoObjectId } from
|
|
1
|
+
import { getDb, ObjectId, City } from "../index";
|
|
2
|
+
import { Collection, Filter, ObjectId as MongoObjectId } from "mongodb";
|
|
3
3
|
|
|
4
4
|
export const getCitiesCollection = (): Collection<City> => {
|
|
5
|
-
return getDb().collection<City>(
|
|
5
|
+
return getDb().collection<City>("cities");
|
|
6
6
|
};
|
|
7
7
|
|
|
8
|
-
export const findCities = async (
|
|
8
|
+
export const findCities = async (
|
|
9
|
+
filter: Filter<City> = {},
|
|
10
|
+
): Promise<City[]> => {
|
|
9
11
|
return await getCitiesCollection().find(filter).toArray();
|
|
10
12
|
};
|
|
11
13
|
|
|
12
14
|
export const getCityById = async (cityId: string): Promise<City | null> => {
|
|
13
|
-
const city = await getCitiesCollection().findOne({
|
|
15
|
+
const city = await getCitiesCollection().findOne({
|
|
16
|
+
_id: new ObjectId(cityId),
|
|
17
|
+
});
|
|
14
18
|
return city ? city : null;
|
|
15
19
|
};
|
|
16
20
|
|
|
17
21
|
export const createCity = async (
|
|
18
|
-
cityData: Omit<City,
|
|
22
|
+
cityData: Omit<City, "_id" | "createdAt" | "updatedAt">,
|
|
19
23
|
): Promise<MongoObjectId> => {
|
|
20
|
-
const city: Omit<City,
|
|
24
|
+
const city: Omit<City, "_id"> = {
|
|
21
25
|
...cityData,
|
|
22
26
|
createdAt: new Date(),
|
|
23
27
|
updatedAt: new Date(),
|
|
@@ -28,17 +32,19 @@ export const createCity = async (
|
|
|
28
32
|
|
|
29
33
|
export const updateCity = async (
|
|
30
34
|
cityId: string,
|
|
31
|
-
data: Partial<Omit<City,
|
|
35
|
+
data: Partial<Omit<City, "_id" | "createdAt" | "updatedAt">>,
|
|
32
36
|
): Promise<City | null> => {
|
|
33
37
|
const result = await getCitiesCollection().findOneAndUpdate(
|
|
34
38
|
{ _id: new ObjectId(cityId) },
|
|
35
39
|
{ $set: { ...data, updatedAt: new Date() } },
|
|
36
|
-
{ returnDocument:
|
|
40
|
+
{ returnDocument: "after" },
|
|
37
41
|
);
|
|
38
42
|
return result || null;
|
|
39
43
|
};
|
|
40
44
|
|
|
41
45
|
export const deleteCity = async (cityId: string): Promise<boolean> => {
|
|
42
|
-
const result = await getCitiesCollection().deleteOne({
|
|
46
|
+
const result = await getCitiesCollection().deleteOne({
|
|
47
|
+
_id: new ObjectId(cityId),
|
|
48
|
+
});
|
|
43
49
|
return result.deletedCount > 0;
|
|
44
50
|
};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from
|
|
2
|
-
export type { City, CityDoc } from
|
|
1
|
+
export * from "./cities.getters";
|
|
2
|
+
export type { City, CityDoc } from "./cities.types";
|