@talkpilot/core-db 1.0.1
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/.cursor/rules/development.mdc +65 -0
- package/DEVELOPMENT.md +98 -0
- package/README.md +140 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +29 -0
- package/dist/index.js.map +1 -0
- package/dist/municipal/cities/cities.getters.d.ts +9 -0
- package/dist/municipal/cities/cities.getters.d.ts.map +1 -0
- package/dist/municipal/cities/cities.getters.js +38 -0
- package/dist/municipal/cities/cities.getters.js.map +1 -0
- package/dist/municipal/cities/cities.types.d.ts +10 -0
- package/dist/municipal/cities/cities.types.d.ts.map +1 -0
- package/dist/municipal/cities/cities.types.js +3 -0
- package/dist/municipal/cities/cities.types.js.map +1 -0
- package/dist/municipal/cities/index.d.ts +3 -0
- package/dist/municipal/cities/index.d.ts.map +1 -0
- package/dist/municipal/cities/index.js +18 -0
- package/dist/municipal/cities/index.js.map +1 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.d.ts +62 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.d.ts.map +1 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.js +180 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.getters.js.map +1 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.d.ts +69 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.d.ts.map +1 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.js +3 -0
- package/dist/municipal/departmentsSubjects/departmentsSubjects.types.js.map +1 -0
- package/dist/municipal/departmentsSubjects/index.d.ts +3 -0
- package/dist/municipal/departmentsSubjects/index.d.ts.map +1 -0
- package/dist/municipal/departmentsSubjects/index.js +18 -0
- package/dist/municipal/departmentsSubjects/index.js.map +1 -0
- package/dist/municipal/index.d.ts +10 -0
- package/dist/municipal/index.d.ts.map +1 -0
- package/dist/municipal/index.js +37 -0
- package/dist/municipal/index.js.map +1 -0
- package/dist/municipal/mongodb-client.d.ts +13 -0
- package/dist/municipal/mongodb-client.d.ts.map +1 -0
- package/dist/municipal/mongodb-client.js +56 -0
- package/dist/municipal/mongodb-client.js.map +1 -0
- package/dist/municipal/streets/index.d.ts +3 -0
- package/dist/municipal/streets/index.d.ts.map +1 -0
- package/dist/municipal/streets/index.js +18 -0
- package/dist/municipal/streets/index.js.map +1 -0
- package/dist/municipal/streets/streets.getters.d.ts +21 -0
- package/dist/municipal/streets/streets.getters.d.ts.map +1 -0
- package/dist/municipal/streets/streets.getters.js +85 -0
- package/dist/municipal/streets/streets.getters.js.map +1 -0
- package/dist/municipal/streets/streets.types.d.ts +16 -0
- package/dist/municipal/streets/streets.types.d.ts.map +1 -0
- package/dist/municipal/streets/streets.types.js +3 -0
- package/dist/municipal/streets/streets.types.js.map +1 -0
- package/dist/municipal/tickets/index.d.ts +3 -0
- package/dist/municipal/tickets/index.d.ts.map +1 -0
- package/dist/municipal/tickets/index.js +18 -0
- package/dist/municipal/tickets/index.js.map +1 -0
- package/dist/municipal/tickets/tickets.getters.d.ts +44 -0
- package/dist/municipal/tickets/tickets.getters.d.ts.map +1 -0
- package/dist/municipal/tickets/tickets.getters.js +199 -0
- package/dist/municipal/tickets/tickets.getters.js.map +1 -0
- package/dist/municipal/tickets/tickets.types.d.ts +35 -0
- package/dist/municipal/tickets/tickets.types.d.ts.map +1 -0
- package/dist/municipal/tickets/tickets.types.js +3 -0
- package/dist/municipal/tickets/tickets.types.js.map +1 -0
- package/dist/talkpilot/agents/agents.getters.d.ts +9 -0
- package/dist/talkpilot/agents/agents.getters.d.ts.map +1 -0
- package/dist/talkpilot/agents/agents.getters.js +34 -0
- package/dist/talkpilot/agents/agents.getters.js.map +1 -0
- package/dist/talkpilot/agents/agents.types.d.ts +13 -0
- package/dist/talkpilot/agents/agents.types.d.ts.map +1 -0
- package/dist/talkpilot/agents/agents.types.js +3 -0
- package/dist/talkpilot/agents/agents.types.js.map +1 -0
- package/dist/talkpilot/agents/index.d.ts +3 -0
- package/dist/talkpilot/agents/index.d.ts.map +1 -0
- package/dist/talkpilot/agents/index.js +19 -0
- package/dist/talkpilot/agents/index.js.map +1 -0
- package/dist/talkpilot/calls/calls.getters.d.ts +24 -0
- package/dist/talkpilot/calls/calls.getters.d.ts.map +1 -0
- package/dist/talkpilot/calls/calls.getters.js +151 -0
- package/dist/talkpilot/calls/calls.getters.js.map +1 -0
- package/dist/talkpilot/calls/calls.types.d.ts +32 -0
- package/dist/talkpilot/calls/calls.types.d.ts.map +1 -0
- package/dist/talkpilot/calls/calls.types.js +3 -0
- package/dist/talkpilot/calls/calls.types.js.map +1 -0
- package/dist/talkpilot/calls/index.d.ts +3 -0
- package/dist/talkpilot/calls/index.d.ts.map +1 -0
- package/dist/talkpilot/calls/index.js +19 -0
- package/dist/talkpilot/calls/index.js.map +1 -0
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.d.ts +9 -0
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.d.ts.map +1 -0
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.js +76 -0
- package/dist/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.js.map +1 -0
- package/dist/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.d.ts +23 -0
- package/dist/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.d.ts.map +1 -0
- package/dist/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.js +3 -0
- package/dist/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.js.map +1 -0
- package/dist/talkpilot/clients/clients.getters.d.ts +5 -0
- package/dist/talkpilot/clients/clients.getters.d.ts.map +1 -0
- package/dist/talkpilot/clients/clients.getters.js +14 -0
- package/dist/talkpilot/clients/clients.getters.js.map +1 -0
- package/dist/talkpilot/clients/clients.types.d.ts +12 -0
- package/dist/talkpilot/clients/clients.types.d.ts.map +1 -0
- package/dist/talkpilot/clients/clients.types.js +3 -0
- package/dist/talkpilot/clients/clients.types.js.map +1 -0
- package/dist/talkpilot/clients/index.d.ts +3 -0
- package/dist/talkpilot/clients/index.d.ts.map +1 -0
- package/dist/talkpilot/clients/index.js +18 -0
- package/dist/talkpilot/clients/index.js.map +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts +7 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts.map +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js +21 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js.map +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts +53 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts.map +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.types.js +3 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.types.js.map +1 -0
- package/dist/talkpilot/clientsConfig/index.d.ts +3 -0
- package/dist/talkpilot/clientsConfig/index.d.ts.map +1 -0
- package/dist/talkpilot/clientsConfig/index.js +19 -0
- package/dist/talkpilot/clientsConfig/index.js.map +1 -0
- package/dist/talkpilot/flows/flows.getter.d.ts +5 -0
- package/dist/talkpilot/flows/flows.getter.d.ts.map +1 -0
- package/dist/talkpilot/flows/flows.getter.js +13 -0
- package/dist/talkpilot/flows/flows.getter.js.map +1 -0
- package/dist/talkpilot/flows/flows.schema.d.ts +154 -0
- package/dist/talkpilot/flows/flows.schema.d.ts.map +1 -0
- package/dist/talkpilot/flows/flows.schema.js +94 -0
- package/dist/talkpilot/flows/flows.schema.js.map +1 -0
- package/dist/talkpilot/flows/flows.types.d.ts +116 -0
- package/dist/talkpilot/flows/flows.types.d.ts.map +1 -0
- package/dist/talkpilot/flows/flows.types.js +3 -0
- package/dist/talkpilot/flows/flows.types.js.map +1 -0
- package/dist/talkpilot/flows/index.d.ts +3 -0
- package/dist/talkpilot/flows/index.d.ts.map +1 -0
- package/dist/talkpilot/flows/index.js +6 -0
- package/dist/talkpilot/flows/index.js.map +1 -0
- package/dist/talkpilot/groups/groups.getters.d.ts +8 -0
- package/dist/talkpilot/groups/groups.getters.d.ts.map +1 -0
- package/dist/talkpilot/groups/groups.getters.js +26 -0
- package/dist/talkpilot/groups/groups.getters.js.map +1 -0
- package/dist/talkpilot/groups/groups.types.d.ts +26 -0
- package/dist/talkpilot/groups/groups.types.d.ts.map +1 -0
- package/dist/talkpilot/groups/groups.types.js +3 -0
- package/dist/talkpilot/groups/groups.types.js.map +1 -0
- package/dist/talkpilot/groups/index.d.ts +3 -0
- package/dist/talkpilot/groups/index.d.ts.map +1 -0
- package/dist/talkpilot/groups/index.js +19 -0
- package/dist/talkpilot/groups/index.js.map +1 -0
- package/dist/talkpilot/groups/phone.utils.d.ts +4 -0
- package/dist/talkpilot/groups/phone.utils.d.ts.map +1 -0
- package/dist/talkpilot/groups/phone.utils.js +42 -0
- package/dist/talkpilot/groups/phone.utils.js.map +1 -0
- package/dist/talkpilot/index.d.ts +19 -0
- package/dist/talkpilot/index.d.ts.map +1 -0
- package/dist/talkpilot/index.js +46 -0
- package/dist/talkpilot/index.js.map +1 -0
- package/dist/talkpilot/leads/index.d.ts +3 -0
- package/dist/talkpilot/leads/index.d.ts.map +1 -0
- package/dist/talkpilot/leads/index.js +6 -0
- package/dist/talkpilot/leads/index.js.map +1 -0
- package/dist/talkpilot/leads/leads.getter.d.ts +4 -0
- package/dist/talkpilot/leads/leads.getter.d.ts.map +1 -0
- package/dist/talkpilot/leads/leads.getter.js +7 -0
- package/dist/talkpilot/leads/leads.getter.js.map +1 -0
- package/dist/talkpilot/leads/leads.schema.d.ts +50 -0
- package/dist/talkpilot/leads/leads.schema.d.ts.map +1 -0
- package/dist/talkpilot/leads/leads.schema.js +37 -0
- package/dist/talkpilot/leads/leads.schema.js.map +1 -0
- package/dist/talkpilot/leads/leads.types.d.ts +18 -0
- package/dist/talkpilot/leads/leads.types.d.ts.map +1 -0
- package/dist/talkpilot/leads/leads.types.js +3 -0
- package/dist/talkpilot/leads/leads.types.js.map +1 -0
- package/dist/talkpilot/mongodb-client.d.ts +13 -0
- package/dist/talkpilot/mongodb-client.d.ts.map +1 -0
- package/dist/talkpilot/mongodb-client.js +71 -0
- package/dist/talkpilot/mongodb-client.js.map +1 -0
- package/dist/talkpilot/phone_numbers/index.d.ts +3 -0
- package/dist/talkpilot/phone_numbers/index.d.ts.map +1 -0
- package/dist/talkpilot/phone_numbers/index.js +18 -0
- package/dist/talkpilot/phone_numbers/index.js.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts +8 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.js +44 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.getter.js.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.d.ts +29 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.d.ts.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.js +18 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.schema.js.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.types.d.ts +16 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.types.d.ts.map +1 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.types.js +3 -0
- package/dist/talkpilot/phone_numbers/phone_numbers.types.js.map +1 -0
- package/dist/talkpilot/plans/index.d.ts +3 -0
- package/dist/talkpilot/plans/index.d.ts.map +1 -0
- package/dist/talkpilot/plans/index.js +19 -0
- package/dist/talkpilot/plans/index.js.map +1 -0
- package/dist/talkpilot/plans/plans.getters.d.ts +10 -0
- package/dist/talkpilot/plans/plans.getters.d.ts.map +1 -0
- package/dist/talkpilot/plans/plans.getters.js +103 -0
- package/dist/talkpilot/plans/plans.getters.js.map +1 -0
- package/dist/talkpilot/plans/plans.types.d.ts +53 -0
- package/dist/talkpilot/plans/plans.types.d.ts.map +1 -0
- package/dist/talkpilot/plans/plans.types.js +29 -0
- package/dist/talkpilot/plans/plans.types.js.map +1 -0
- package/dist/talkpilot/results/index.d.ts +3 -0
- package/dist/talkpilot/results/index.d.ts.map +1 -0
- package/dist/talkpilot/results/index.js +6 -0
- package/dist/talkpilot/results/index.js.map +1 -0
- package/dist/talkpilot/results/results.getter.d.ts +7 -0
- package/dist/talkpilot/results/results.getter.d.ts.map +1 -0
- package/dist/talkpilot/results/results.getter.js +26 -0
- package/dist/talkpilot/results/results.getter.js.map +1 -0
- package/dist/talkpilot/results/results.schema.d.ts +35 -0
- package/dist/talkpilot/results/results.schema.d.ts.map +1 -0
- package/dist/talkpilot/results/results.schema.js +29 -0
- package/dist/talkpilot/results/results.schema.js.map +1 -0
- package/dist/talkpilot/results/results.types.d.ts +34 -0
- package/dist/talkpilot/results/results.types.d.ts.map +1 -0
- package/dist/talkpilot/results/results.types.js +3 -0
- package/dist/talkpilot/results/results.types.js.map +1 -0
- package/dist/talkpilot/sessions/index.d.ts +3 -0
- package/dist/talkpilot/sessions/index.d.ts.map +1 -0
- package/dist/talkpilot/sessions/index.js +6 -0
- package/dist/talkpilot/sessions/index.js.map +1 -0
- package/dist/talkpilot/sessions/sessions.getter.d.ts +7 -0
- package/dist/talkpilot/sessions/sessions.getter.d.ts.map +1 -0
- package/dist/talkpilot/sessions/sessions.getter.js +26 -0
- package/dist/talkpilot/sessions/sessions.getter.js.map +1 -0
- package/dist/talkpilot/sessions/sessions.schema.d.ts +53 -0
- package/dist/talkpilot/sessions/sessions.schema.d.ts.map +1 -0
- package/dist/talkpilot/sessions/sessions.schema.js +38 -0
- package/dist/talkpilot/sessions/sessions.schema.js.map +1 -0
- package/dist/talkpilot/sessions/sessions.types.d.ts +22 -0
- package/dist/talkpilot/sessions/sessions.types.d.ts.map +1 -0
- package/dist/talkpilot/sessions/sessions.types.js +3 -0
- package/dist/talkpilot/sessions/sessions.types.js.map +1 -0
- package/dist/talkpilot/subscriptions/index.d.ts +4 -0
- package/dist/talkpilot/subscriptions/index.d.ts.map +1 -0
- package/dist/talkpilot/subscriptions/index.js +20 -0
- package/dist/talkpilot/subscriptions/index.js.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.d.ts +13 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.d.ts.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.js +105 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.js.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.d.ts +8 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.d.ts.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.js +27 -0
- package/dist/talkpilot/subscriptions/subscriptions.getters.utils.js.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.types.d.ts +50 -0
- package/dist/talkpilot/subscriptions/subscriptions.types.d.ts.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.types.js +14 -0
- package/dist/talkpilot/subscriptions/subscriptions.types.js.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.utils.d.ts +4 -0
- package/dist/talkpilot/subscriptions/subscriptions.utils.d.ts.map +1 -0
- package/dist/talkpilot/subscriptions/subscriptions.utils.js +20 -0
- package/dist/talkpilot/subscriptions/subscriptions.utils.js.map +1 -0
- package/dist/test-utils/db-utils.d.ts +4 -0
- package/dist/test-utils/db-utils.d.ts.map +1 -0
- package/dist/test-utils/db-utils.js +28 -0
- package/dist/test-utils/db-utils.js.map +1 -0
- package/dist/test-utils/factories/index.d.ts +13 -0
- package/dist/test-utils/factories/index.d.ts.map +1 -0
- package/dist/test-utils/factories/index.js +29 -0
- package/dist/test-utils/factories/index.js.map +1 -0
- package/dist/test-utils/factories/municipal/cities.d.ts +5 -0
- package/dist/test-utils/factories/municipal/cities.d.ts.map +1 -0
- package/dist/test-utils/factories/municipal/cities.js +18 -0
- package/dist/test-utils/factories/municipal/cities.js.map +1 -0
- package/dist/test-utils/factories/municipal/departmentsSubjects.d.ts +5 -0
- package/dist/test-utils/factories/municipal/departmentsSubjects.d.ts.map +1 -0
- package/dist/test-utils/factories/municipal/departmentsSubjects.js +27 -0
- package/dist/test-utils/factories/municipal/departmentsSubjects.js.map +1 -0
- package/dist/test-utils/factories/municipal/streets.d.ts +5 -0
- package/dist/test-utils/factories/municipal/streets.d.ts.map +1 -0
- package/dist/test-utils/factories/municipal/streets.js +19 -0
- package/dist/test-utils/factories/municipal/streets.js.map +1 -0
- package/dist/test-utils/factories/municipal/tickets.d.ts +5 -0
- package/dist/test-utils/factories/municipal/tickets.d.ts.map +1 -0
- package/dist/test-utils/factories/municipal/tickets.js +27 -0
- package/dist/test-utils/factories/municipal/tickets.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/agents.d.ts +5 -0
- package/dist/test-utils/factories/talkpilot/agents.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/agents.js +21 -0
- package/dist/test-utils/factories/talkpilot/agents.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/calls.d.ts +6 -0
- package/dist/test-utils/factories/talkpilot/calls.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/calls.js +39 -0
- package/dist/test-utils/factories/talkpilot/calls.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.d.ts +5 -0
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.js +18 -0
- package/dist/test-utils/factories/talkpilot/clientAudioBuffers.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/clientsConfig.d.ts +5 -0
- package/dist/test-utils/factories/talkpilot/clientsConfig.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/clientsConfig.js +18 -0
- package/dist/test-utils/factories/talkpilot/clientsConfig.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/flows.d.ts +14 -0
- package/dist/test-utils/factories/talkpilot/flows.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/flows.js +33 -0
- package/dist/test-utils/factories/talkpilot/flows.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/groups.d.ts +6 -0
- package/dist/test-utils/factories/talkpilot/groups.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/groups.js +34 -0
- package/dist/test-utils/factories/talkpilot/groups.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/phone_numbers.d.ts +16 -0
- package/dist/test-utils/factories/talkpilot/phone_numbers.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/phone_numbers.js +20 -0
- package/dist/test-utils/factories/talkpilot/phone_numbers.js.map +1 -0
- package/dist/test-utils/factories/talkpilot/sessions.d.ts +5 -0
- package/dist/test-utils/factories/talkpilot/sessions.d.ts.map +1 -0
- package/dist/test-utils/factories/talkpilot/sessions.js +37 -0
- package/dist/test-utils/factories/talkpilot/sessions.js.map +1 -0
- package/dist/utils/validation.d.ts +7 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +23 -0
- package/dist/utils/validation.js.map +1 -0
- package/jest.config.js +22 -0
- package/package.json +43 -0
- package/src/__tests__/setup.ts +20 -0
- package/src/index.ts +13 -0
- package/src/municipal/__tests__/validation.spec.ts +50 -0
- package/src/municipal/cities/cities.getters.ts +44 -0
- package/src/municipal/cities/cities.types.ts +11 -0
- package/src/municipal/cities/index.ts +2 -0
- package/src/municipal/departmentsSubjects/departmentsSubjects.getters.ts +273 -0
- package/src/municipal/departmentsSubjects/departmentsSubjects.types.ts +76 -0
- package/src/municipal/departmentsSubjects/index.ts +11 -0
- package/src/municipal/index.ts +18 -0
- package/src/municipal/mongodb-client.ts +58 -0
- package/src/municipal/streets/index.ts +2 -0
- package/src/municipal/streets/streets.getters.ts +105 -0
- package/src/municipal/streets/streets.types.ts +18 -0
- package/src/municipal/tickets/__tests__/tickets.getters.spec.ts +30 -0
- package/src/municipal/tickets/index.ts +2 -0
- package/src/municipal/tickets/tickets.getters.ts +234 -0
- package/src/municipal/tickets/tickets.types.ts +39 -0
- package/src/talkpilot/__tests__/db.spec.ts +38 -0
- package/src/talkpilot/__tests__/mongodb-client.spec.ts +19 -0
- package/src/talkpilot/__tests__/validation.spec.ts +62 -0
- package/src/talkpilot/agents/__tests__/agents.getters.spec.ts +29 -0
- package/src/talkpilot/agents/agents.getters.ts +34 -0
- package/src/talkpilot/agents/agents.types.ts +14 -0
- package/src/talkpilot/agents/index.ts +2 -0
- package/src/talkpilot/calls/__tests__/calls.spec.ts +56 -0
- package/src/talkpilot/calls/calls.getters.ts +134 -0
- package/src/talkpilot/calls/calls.types.ts +45 -0
- package/src/talkpilot/calls/index.ts +2 -0
- package/src/talkpilot/clientAudioBuffers/__tests__/clientAudioBuffer.getters.spec.ts +78 -0
- package/src/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.ts +101 -0
- package/src/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.ts +25 -0
- package/src/talkpilot/clients/clients.getters.ts +11 -0
- package/src/talkpilot/clients/clients.types.ts +12 -0
- package/src/talkpilot/clients/index.ts +2 -0
- package/src/talkpilot/clientsConfig/__tests__/clientsConfig.spec.ts +28 -0
- package/src/talkpilot/clientsConfig/clientsConfig.getters.ts +20 -0
- package/src/talkpilot/clientsConfig/clientsConfig.types.ts +55 -0
- package/src/talkpilot/clientsConfig/index.ts +2 -0
- package/src/talkpilot/flows/flows.getter.ts +11 -0
- package/src/talkpilot/flows/flows.schema.ts +90 -0
- package/src/talkpilot/flows/flows.types.ts +151 -0
- package/src/talkpilot/flows/index.ts +2 -0
- package/src/talkpilot/groups/__tests__/groups.spec.ts +83 -0
- package/src/talkpilot/groups/__tests__/phone.utils.spec.ts +32 -0
- package/src/talkpilot/groups/groups.getters.ts +27 -0
- package/src/talkpilot/groups/groups.types.ts +29 -0
- package/src/talkpilot/groups/index.ts +2 -0
- package/src/talkpilot/groups/phone.utils.ts +40 -0
- package/src/talkpilot/index.ts +27 -0
- package/src/talkpilot/leads/index.ts +2 -0
- package/src/talkpilot/leads/leads.getter.ts +5 -0
- package/src/talkpilot/leads/leads.schema.ts +33 -0
- package/src/talkpilot/leads/leads.types.ts +20 -0
- package/src/talkpilot/mongodb-client.ts +78 -0
- package/src/talkpilot/phone_numbers/__tests__/phone_numbers.spec.ts +43 -0
- package/src/talkpilot/phone_numbers/index.ts +2 -0
- package/src/talkpilot/phone_numbers/phone_numbers.getter.ts +47 -0
- package/src/talkpilot/phone_numbers/phone_numbers.schema.ts +14 -0
- package/src/talkpilot/phone_numbers/phone_numbers.types.ts +15 -0
- package/src/talkpilot/plans/index.ts +2 -0
- package/src/talkpilot/plans/plans.getters.ts +121 -0
- package/src/talkpilot/plans/plans.types.ts +84 -0
- package/src/talkpilot/results/index.ts +2 -0
- package/src/talkpilot/results/results.getter.ts +26 -0
- package/src/talkpilot/results/results.schema.ts +25 -0
- package/src/talkpilot/results/results.types.ts +32 -0
- package/src/talkpilot/sessions/__tests__/sessions.spec.ts +43 -0
- package/src/talkpilot/sessions/index.ts +2 -0
- package/src/talkpilot/sessions/sessions.getter.ts +28 -0
- package/src/talkpilot/sessions/sessions.schema.ts +34 -0
- package/src/talkpilot/sessions/sessions.types.ts +28 -0
- package/src/talkpilot/subscriptions/__tests__/subscriptions.getters.utils.spec.ts +42 -0
- package/src/talkpilot/subscriptions/index.ts +3 -0
- package/src/talkpilot/subscriptions/subscriptions.getters.ts +147 -0
- package/src/talkpilot/subscriptions/subscriptions.getters.utils.ts +26 -0
- package/src/talkpilot/subscriptions/subscriptions.types.ts +65 -0
- package/src/test-utils/db-utils.ts +24 -0
- package/src/test-utils/factories/index.ts +12 -0
- package/src/test-utils/factories/municipal/cities.ts +16 -0
- package/src/test-utils/factories/municipal/departmentsSubjects.ts +29 -0
- package/src/test-utils/factories/municipal/streets.ts +17 -0
- package/src/test-utils/factories/municipal/tickets.ts +27 -0
- package/src/test-utils/factories/talkpilot/agents.ts +19 -0
- package/src/test-utils/factories/talkpilot/calls.ts +37 -0
- package/src/test-utils/factories/talkpilot/clientAudioBuffers.ts +18 -0
- package/src/test-utils/factories/talkpilot/clientsConfig.ts +19 -0
- package/src/test-utils/factories/talkpilot/flows.ts +31 -0
- package/src/test-utils/factories/talkpilot/groups.ts +33 -0
- package/src/test-utils/factories/talkpilot/phone_numbers.ts +20 -0
- package/src/test-utils/factories/talkpilot/sessions.ts +35 -0
- package/src/utils/validation.ts +23 -0
- package/tsconfig.json +27 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.callFactory = void 0;
|
|
4
|
+
exports.createOutGoingCallDoc = createOutGoingCallDoc;
|
|
5
|
+
exports.createIncomingCallDoc = createIncomingCallDoc;
|
|
6
|
+
const fishery_1 = require("fishery");
|
|
7
|
+
const mongodb_1 = require("mongodb");
|
|
8
|
+
const faker_1 = require("@faker-js/faker");
|
|
9
|
+
exports.callFactory = fishery_1.Factory.define(() => ({
|
|
10
|
+
callSid: faker_1.faker.string.uuid(),
|
|
11
|
+
flowId: new mongodb_1.ObjectId(),
|
|
12
|
+
clientId: faker_1.faker.string.uuid(),
|
|
13
|
+
sessionId: null,
|
|
14
|
+
resultId: new mongodb_1.ObjectId(),
|
|
15
|
+
customerPhoneNumber: faker_1.faker.phone.number(),
|
|
16
|
+
agentPhoneNumber: faker_1.faker.phone.number(),
|
|
17
|
+
isIncomingCall: false,
|
|
18
|
+
isOutgoingCall: true,
|
|
19
|
+
callLength: faker_1.faker.number.int({ min: 0, max: 3600 }),
|
|
20
|
+
env: 'test',
|
|
21
|
+
updatedAt: new Date(),
|
|
22
|
+
createdAt: new Date(),
|
|
23
|
+
}));
|
|
24
|
+
function createOutGoingCallDoc(overrides) {
|
|
25
|
+
return exports.callFactory.build({
|
|
26
|
+
...overrides,
|
|
27
|
+
isIncomingCall: false,
|
|
28
|
+
isOutgoingCall: true,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
function createIncomingCallDoc(overrides) {
|
|
32
|
+
return exports.callFactory.build({
|
|
33
|
+
...overrides,
|
|
34
|
+
isIncomingCall: true,
|
|
35
|
+
isOutgoingCall: false,
|
|
36
|
+
sessionId: overrides?.sessionId ?? null,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=calls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calls.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/calls.ts"],"names":[],"mappings":";;;AAqBA,sDAMC;AAED,sDAOC;AApCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,WAAW,GAAG,iBAAO,CAAC,MAAM,CAAO,GAAG,EAAE,CAAC,CAAC;IACrD,OAAO,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC5B,MAAM,EAAE,IAAI,kBAAQ,EAAE;IACtB,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC7B,SAAS,EAAE,IAAI;IACf,QAAQ,EAAE,IAAI,kBAAQ,EAAE;IACxB,mBAAmB,EAAE,aAAK,CAAC,KAAK,CAAC,MAAM,EAAE;IACzC,gBAAgB,EAAE,aAAK,CAAC,KAAK,CAAC,MAAM,EAAE;IACtC,cAAc,EAAE,KAAK;IACrB,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,aAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;IACnD,GAAG,EAAE,MAAM;IACX,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,SAAS,EAAE,IAAI,IAAI,EAAE;CACtB,CAAC,CAAC,CAAC;AAEJ,SAAgB,qBAAqB,CAAC,SAAyB;IAC7D,OAAO,mBAAW,CAAC,KAAK,CAAC;QACvB,GAAG,SAAS;QACZ,cAAc,EAAE,KAAK;QACrB,cAAc,EAAE,IAAI;KACrB,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,qBAAqB,CAAC,SAAyB;IAC7D,OAAO,mBAAW,CAAC,KAAK,CAAC;QACvB,GAAG,SAAS;QACZ,cAAc,EAAE,IAAI;QACpB,cAAc,EAAE,KAAK;QACrB,SAAS,EAAE,SAAS,EAAE,SAAS,IAAI,IAAI;KACxC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import { CreateAudioBufferInput } from '../../../talkpilot/clientAudioBuffers/clientsAudioBuffers.types';
|
|
3
|
+
export declare const audioBufferInputFactory: Factory<CreateAudioBufferInput, any, CreateAudioBufferInput, import("fishery").DeepPartialObject<CreateAudioBufferInput>>;
|
|
4
|
+
export declare function createAudioBufferInput(overrides?: Partial<CreateAudioBufferInput>): CreateAudioBufferInput;
|
|
5
|
+
//# sourceMappingURL=clientAudioBuffers.d.ts.map
|
|
@@ -0,0 +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,iEAAiE,CAAC;AAEzG,eAAO,MAAM,uBAAuB,2HAOjC,CAAC;AAEJ,wBAAgB,sBAAsB,CACpC,SAAS,CAAC,EAAE,OAAO,CAAC,sBAAsB,CAAC,GAC1C,sBAAsB,CAExB"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.audioBufferInputFactory = void 0;
|
|
4
|
+
exports.createAudioBufferInput = createAudioBufferInput;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const faker_1 = require("@faker-js/faker");
|
|
7
|
+
exports.audioBufferInputFactory = fishery_1.Factory.define(() => ({
|
|
8
|
+
callSid: 'CA1234567890abcdef1234567890abcdef',
|
|
9
|
+
clientId: faker_1.faker.string.uuid(),
|
|
10
|
+
bucketStartMs: faker_1.faker.number.int({ min: 0, max: 1000000 }),
|
|
11
|
+
bucketDurationMs: faker_1.faker.helpers.arrayElement([500, 1000]),
|
|
12
|
+
data: Buffer.from(faker_1.faker.string.alphanumeric({ length: 100 })),
|
|
13
|
+
ttlMs: faker_1.faker.number.int({ min: 1000, max: 3600000 }),
|
|
14
|
+
}));
|
|
15
|
+
function createAudioBufferInput(overrides) {
|
|
16
|
+
return exports.audioBufferInputFactory.build(overrides ?? {});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=clientAudioBuffers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientAudioBuffers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientAudioBuffers.ts"],"names":[],"mappings":";;;AAaA,wDAIC;AAjBD,qCAAkC;AAClC,2CAAwC;AAG3B,QAAA,uBAAuB,GAAG,iBAAO,CAAC,MAAM,CAAyB,GAAG,EAAE,CAAC,CAAC;IACnF,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,CAAC,CAAC;AAEJ,SAAgB,sBAAsB,CACpC,SAA2C;IAE3C,OAAO,+BAAuB,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;AACxD,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import type { ClientConfig, ClientConfigDoc } from '../../../talkpilot/clientsConfig/clientsConfig.types';
|
|
3
|
+
export declare const clientConfigFactory: Factory<ClientConfigDoc, any, ClientConfigDoc, import("fishery").DeepPartialObject<ClientConfigDoc>>;
|
|
4
|
+
export declare function createClientConfig(overrides?: Partial<ClientConfig>): ClientConfigDoc;
|
|
5
|
+
//# sourceMappingURL=clientsConfig.d.ts.map
|
|
@@ -0,0 +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,EACV,YAAY,EACZ,eAAe,EAChB,MAAM,sDAAsD,CAAC;AAE9D,eAAO,MAAM,mBAAmB,sGAI7B,CAAC;AAEJ,wBAAgB,kBAAkB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,eAAe,CAIrF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.clientConfigFactory = void 0;
|
|
4
|
+
exports.createClientConfig = createClientConfig;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const mongodb_1 = require("mongodb");
|
|
7
|
+
const faker_1 = require("@faker-js/faker");
|
|
8
|
+
exports.clientConfigFactory = fishery_1.Factory.define(() => ({
|
|
9
|
+
_id: new mongodb_1.ObjectId(),
|
|
10
|
+
clientId: faker_1.faker.string.uuid(),
|
|
11
|
+
products: {},
|
|
12
|
+
}));
|
|
13
|
+
function createClientConfig(overrides) {
|
|
14
|
+
return exports.clientConfigFactory.build({
|
|
15
|
+
...overrides,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=clientsConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientsConfig.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/clientsConfig.ts"],"names":[],"mappings":";;;AAcA,gDAIC;AAlBD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAM3B,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,CAAC,SAAiC;IAClE,OAAO,2BAAmB,CAAC,KAAK,CAAC;QAC/B,GAAG,SAAS;KACb,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import { ObjectId } from 'mongodb';
|
|
3
|
+
import type { Flow } from '../../../talkpilot/flows/flows.types';
|
|
4
|
+
export declare const flowFactory: Factory<Flow & {
|
|
5
|
+
_id: ObjectId;
|
|
6
|
+
}, any, Flow & {
|
|
7
|
+
_id: ObjectId;
|
|
8
|
+
}, import("fishery").DeepPartialObject<Flow & {
|
|
9
|
+
_id: ObjectId;
|
|
10
|
+
}>>;
|
|
11
|
+
export declare function createFlow(overrides?: Partial<Flow>): Flow & {
|
|
12
|
+
_id: ObjectId;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=flows.d.ts.map
|
|
@@ -0,0 +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,sCAAsC,CAAC;AAEjE,eAAO,MAAM,WAAW;SAAgC,QAAQ;;SAAR,QAAQ;;SAAR,QAAQ;GAa9D,CAAC;AAEH,wBAAgB,UAAU,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,GAAG;IAAE,GAAG,EAAE,QAAQ,CAAA;CAAE,CAU9E"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.flowFactory = void 0;
|
|
4
|
+
exports.createFlow = createFlow;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const mongodb_1 = require("mongodb");
|
|
7
|
+
const faker_1 = require("@faker-js/faker");
|
|
8
|
+
exports.flowFactory = fishery_1.Factory.define(() => {
|
|
9
|
+
const now = new Date();
|
|
10
|
+
return {
|
|
11
|
+
_id: new mongodb_1.ObjectId(),
|
|
12
|
+
flowName: faker_1.faker.lorem.words(2),
|
|
13
|
+
clientId: faker_1.faker.string.uuid(),
|
|
14
|
+
systemInstructions: faker_1.faker.lorem.sentences(2),
|
|
15
|
+
initialSentence: faker_1.faker.lorem.sentence(),
|
|
16
|
+
insights: [],
|
|
17
|
+
interactions: [],
|
|
18
|
+
createdAt: now,
|
|
19
|
+
updatedAt: now,
|
|
20
|
+
};
|
|
21
|
+
});
|
|
22
|
+
function createFlow(overrides) {
|
|
23
|
+
const now = new Date();
|
|
24
|
+
const base = exports.flowFactory.build();
|
|
25
|
+
return {
|
|
26
|
+
...base,
|
|
27
|
+
...overrides,
|
|
28
|
+
_id: overrides?._id ?? base._id,
|
|
29
|
+
updatedAt: now,
|
|
30
|
+
createdAt: overrides?.createdAt ?? now,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=flows.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flows.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/flows.ts"],"names":[],"mappings":";;;AAoBA,gCAUC;AA9BD,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,CAAC,SAAyB;IAClD,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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import type { Group, GroupContact, GroupDoc } from '../../../talkpilot/groups/groups.types';
|
|
3
|
+
export declare const groupContactFactory: Factory<GroupContact, any, GroupContact, import("fishery").DeepPartialObject<GroupContact>>;
|
|
4
|
+
export declare const groupFactory: Factory<GroupDoc, any, GroupDoc, import("fishery").DeepPartialObject<GroupDoc>>;
|
|
5
|
+
export declare function createGroup(overrides?: Partial<Group>): GroupDoc;
|
|
6
|
+
//# sourceMappingURL=groups.d.ts.map
|
|
@@ -0,0 +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,wCAAwC,CAAC;AAE5F,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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.groupFactory = exports.groupContactFactory = void 0;
|
|
4
|
+
exports.createGroup = createGroup;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const mongodb_1 = require("mongodb");
|
|
7
|
+
const faker_1 = require("@faker-js/faker");
|
|
8
|
+
exports.groupContactFactory = fishery_1.Factory.define(() => ({
|
|
9
|
+
name: faker_1.faker.person.firstName(),
|
|
10
|
+
phone: {
|
|
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
|
+
},
|
|
20
|
+
gender: faker_1.faker.helpers.arrayElement(['male', 'female']),
|
|
21
|
+
}));
|
|
22
|
+
exports.groupFactory = fishery_1.Factory.define(() => ({
|
|
23
|
+
_id: new mongodb_1.ObjectId(),
|
|
24
|
+
clientId: faker_1.faker.string.uuid(),
|
|
25
|
+
createdAt: new Date(),
|
|
26
|
+
updatedAt: new Date(),
|
|
27
|
+
name: faker_1.faker.company.name(),
|
|
28
|
+
description: faker_1.faker.lorem.sentence(),
|
|
29
|
+
contacts: exports.groupContactFactory.buildList(2),
|
|
30
|
+
}));
|
|
31
|
+
function createGroup(overrides) {
|
|
32
|
+
return exports.groupFactory.build(overrides);
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=groups.js.map
|
|
@@ -0,0 +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;QACpB,YAAY,EAAE,WAAW;QACzB,UAAU,EAAE,WAAW;QACvB,YAAY,EAAE,WAAW;QAC1B,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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import { ObjectId } from 'mongodb';
|
|
3
|
+
import type { PhoneNumber } from '../../../talkpilot/phone_numbers/phone_numbers.types';
|
|
4
|
+
export declare const phoneNumberFactory: Factory<PhoneNumber & {
|
|
5
|
+
_id?: ObjectId;
|
|
6
|
+
}, any, PhoneNumber & {
|
|
7
|
+
_id?: ObjectId;
|
|
8
|
+
}, import("fishery").DeepPartialObject<PhoneNumber & {
|
|
9
|
+
_id?: ObjectId;
|
|
10
|
+
}>>;
|
|
11
|
+
export declare function createPhoneNumber(overrides?: Partial<PhoneNumber> & {
|
|
12
|
+
flow_id?: ObjectId;
|
|
13
|
+
}): PhoneNumber & {
|
|
14
|
+
_id?: ObjectId;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=phone_numbers.d.ts.map
|
|
@@ -0,0 +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,sDAAsD,CAAC;AAExF,eAAO,MAAM,kBAAkB;UAAwC,QAAQ;;UAAR,QAAQ;;UAAR,QAAQ;GAQ5E,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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.phoneNumberFactory = void 0;
|
|
4
|
+
exports.createPhoneNumber = createPhoneNumber;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const mongodb_1 = require("mongodb");
|
|
7
|
+
const faker_1 = require("@faker-js/faker");
|
|
8
|
+
exports.phoneNumberFactory = fishery_1.Factory.define(() => ({
|
|
9
|
+
_id: new mongodb_1.ObjectId(),
|
|
10
|
+
client_id: faker_1.faker.string.uuid(),
|
|
11
|
+
flow_id: new mongodb_1.ObjectId(),
|
|
12
|
+
phone_number: faker_1.faker.phone.number(),
|
|
13
|
+
createdAt: new Date(),
|
|
14
|
+
updatedAt: new Date(),
|
|
15
|
+
is_primary: true,
|
|
16
|
+
}));
|
|
17
|
+
function createPhoneNumber(overrides) {
|
|
18
|
+
return exports.phoneNumberFactory.build(overrides);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=phone_numbers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"phone_numbers.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/phone_numbers.ts"],"names":[],"mappings":";;;AAeA,8CAIC;AAnBD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,kBAAkB,GAAG,iBAAO,CAAC,MAAM,CAAmC,GAAG,EAAE,CAAC,CAAC;IACxF,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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Factory } from 'fishery';
|
|
2
|
+
import type { Session } from '../../../talkpilot/sessions/sessions.types';
|
|
3
|
+
export declare const sessionFactory: Factory<Session, any, Session, import("fishery").DeepPartialObject<Session>>;
|
|
4
|
+
export declare function createSession(overrides?: Partial<Session>): Session;
|
|
5
|
+
//# sourceMappingURL=sessions.d.ts.map
|
|
@@ -0,0 +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,4CAA4C,CAAC;AAE1E,eAAO,MAAM,cAAc,8EAkBxB,CAAC;AAEJ,wBAAgB,aAAa,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CASnE"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.sessionFactory = void 0;
|
|
4
|
+
exports.createSession = createSession;
|
|
5
|
+
const fishery_1 = require("fishery");
|
|
6
|
+
const mongodb_1 = require("mongodb");
|
|
7
|
+
const faker_1 = require("@faker-js/faker");
|
|
8
|
+
exports.sessionFactory = fishery_1.Factory.define(() => ({
|
|
9
|
+
_id: new mongodb_1.ObjectId(),
|
|
10
|
+
session_name: faker_1.faker.lorem.word(),
|
|
11
|
+
clientId: faker_1.faker.string.uuid(),
|
|
12
|
+
flow_id: new mongodb_1.ObjectId(),
|
|
13
|
+
phone_numbers: [
|
|
14
|
+
{
|
|
15
|
+
name: faker_1.faker.person.firstName(),
|
|
16
|
+
phoneNumber: faker_1.faker.phone.number(),
|
|
17
|
+
gender: 'male',
|
|
18
|
+
},
|
|
19
|
+
],
|
|
20
|
+
json: null,
|
|
21
|
+
metaKeys: null,
|
|
22
|
+
voice: null,
|
|
23
|
+
company_name: null,
|
|
24
|
+
createdAt: new Date(),
|
|
25
|
+
updatedAt: new Date(),
|
|
26
|
+
}));
|
|
27
|
+
function createSession(overrides) {
|
|
28
|
+
const now = new Date();
|
|
29
|
+
const base = exports.sessionFactory.build();
|
|
30
|
+
return {
|
|
31
|
+
...base,
|
|
32
|
+
...overrides,
|
|
33
|
+
createdAt: overrides?.createdAt ?? now,
|
|
34
|
+
updatedAt: now,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../../../src/test-utils/factories/talkpilot/sessions.ts"],"names":[],"mappings":";;;AAyBA,sCASC;AAlCD,qCAAkC;AAClC,qCAAmC;AACnC,2CAAwC;AAG3B,QAAA,cAAc,GAAG,iBAAO,CAAC,MAAM,CAAU,GAAG,EAAE,CAAC,CAAC;IAC3D,GAAG,EAAE,IAAI,kBAAQ,EAAE;IACnB,YAAY,EAAE,aAAK,CAAC,KAAK,CAAC,IAAI,EAAE;IAChC,QAAQ,EAAE,aAAK,CAAC,MAAM,CAAC,IAAI,EAAE;IAC7B,OAAO,EAAE,IAAI,kBAAQ,EAAE;IACvB,aAAa,EAAE;QACb;YACE,IAAI,EAAE,aAAK,CAAC,MAAM,CAAC,SAAS,EAAE;YAC9B,WAAW,EAAE,aAAK,CAAC,KAAK,CAAC,MAAM,EAAE;YACjC,MAAM,EAAE,MAAe;SACxB;KACF;IACD,IAAI,EAAE,IAAI;IACV,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,IAAI;IACX,YAAY,EAAE,IAAI;IAClB,SAAS,EAAE,IAAI,IAAI,EAAE;IACrB,SAAS,EAAE,IAAI,IAAI,EAAE;CACtB,CAAC,CAAC,CAAC;AAEJ,SAAgB,aAAa,CAAC,SAA4B;IACxD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,IAAI,GAAG,sBAAc,CAAC,KAAK,EAAE,CAAC;IACpC,OAAO;QACL,GAAG,IAAI;QACP,GAAG,SAAS;QACZ,SAAS,EAAE,SAAS,EAAE,SAAS,IAAI,GAAG;QACtC,SAAS,EAAE,GAAG;KACf,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Simple validation utilities for the core-db package.
|
|
3
|
+
* Designed to be lightweight and only run when needed.
|
|
4
|
+
*/
|
|
5
|
+
export declare const validateConfig: (configName: string, value?: string) => string;
|
|
6
|
+
export declare const validateMongoUri: (uri: string) => void;
|
|
7
|
+
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,eAAO,MAAM,cAAc,GAAI,YAAY,MAAM,EAAE,QAAQ,MAAM,KAAG,MAQnE,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,KAAK,MAAM,KAAG,IAO9C,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Simple validation utilities for the core-db package.
|
|
4
|
+
* Designed to be lightweight and only run when needed.
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.validateMongoUri = exports.validateConfig = void 0;
|
|
8
|
+
const validateConfig = (configName, value) => {
|
|
9
|
+
if (!value || value.trim() === '') {
|
|
10
|
+
throw new Error(`[core-db] Configuration Error: '${configName}' is missing. ` +
|
|
11
|
+
`Please provide it via parameters or set the corresponding environment variable.`);
|
|
12
|
+
}
|
|
13
|
+
return value;
|
|
14
|
+
};
|
|
15
|
+
exports.validateConfig = validateConfig;
|
|
16
|
+
const validateMongoUri = (uri) => {
|
|
17
|
+
if (!uri.startsWith('mongodb://') && !uri.startsWith('mongodb+srv://')) {
|
|
18
|
+
throw new Error(`[core-db] Connection Error: The provided MongoDB URI is invalid. ` +
|
|
19
|
+
`It must start with 'mongodb://' or 'mongodb+srv://'. Received: '${uri}'`);
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
exports.validateMongoUri = validateMongoUri;
|
|
23
|
+
//# sourceMappingURL=validation.js.map
|
|
@@ -0,0 +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;YAC7D,iFAAiF,CAClF,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;YACnE,mEAAmE,GAAG,GAAG,CAC1E,CAAC;IACJ,CAAC;AACH,CAAC,CAAC;AAPW,QAAA,gBAAgB,oBAO3B"}
|
package/jest.config.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/** @type {import('ts-jest').JestConfigWithTsJest} */
|
|
2
|
+
module.exports = {
|
|
3
|
+
preset: 'ts-jest',
|
|
4
|
+
testEnvironment: 'node',
|
|
5
|
+
roots: ['<rootDir>/src'],
|
|
6
|
+
testPathIgnorePatterns: ['<rootDir>/src/__tests__/legacy/'],
|
|
7
|
+
testMatch: ['**/__tests__/**/*.spec.ts', '**/*.spec.ts'],
|
|
8
|
+
transform: {
|
|
9
|
+
'^.+\\.tsx?$': ['ts-jest', {
|
|
10
|
+
tsconfig: 'tsconfig.json',
|
|
11
|
+
}],
|
|
12
|
+
},
|
|
13
|
+
moduleNameMapper: {
|
|
14
|
+
'^@core/db$': '<rootDir>/src/index.ts',
|
|
15
|
+
},
|
|
16
|
+
setupFilesAfterEnv: ['<rootDir>/src/__tests__/setup.ts'],
|
|
17
|
+
verbose: true,
|
|
18
|
+
forceExit: true,
|
|
19
|
+
clearMocks: true,
|
|
20
|
+
resetMocks: true,
|
|
21
|
+
restoreMocks: true,
|
|
22
|
+
};
|
package/package.json
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@talkpilot/core-db",
|
|
3
|
+
"version": "1.0.1",
|
|
4
|
+
"description": "Core database package for centralized connections and ORM integration.",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc",
|
|
9
|
+
"dev": "tsc --watch",
|
|
10
|
+
"test": "jest",
|
|
11
|
+
"lint": "eslint 'src/**/*.{ts,tsx}'",
|
|
12
|
+
"prepare": "npm run build"
|
|
13
|
+
},
|
|
14
|
+
"keywords": [
|
|
15
|
+
"database",
|
|
16
|
+
"orm",
|
|
17
|
+
"typescript",
|
|
18
|
+
"postgres",
|
|
19
|
+
"db-client"
|
|
20
|
+
],
|
|
21
|
+
"author": "",
|
|
22
|
+
"license": "MIT",
|
|
23
|
+
"dependencies": {
|
|
24
|
+
"express": "^4.18.0",
|
|
25
|
+
"google-libphonenumber": "^3.2.0",
|
|
26
|
+
"mongodb": "^6.0.0"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@faker-js/faker": "^8.0.0",
|
|
30
|
+
"@types/express": "^4.17.0",
|
|
31
|
+
"@types/google-libphonenumber": "^7.4.0",
|
|
32
|
+
"@types/jest": "^29.0.0",
|
|
33
|
+
"@types/node": "^20.0.0",
|
|
34
|
+
"fishery": "^2.4.0",
|
|
35
|
+
"jest": "^29.0.0",
|
|
36
|
+
"mongodb-memory-server": "^10.0.0",
|
|
37
|
+
"ts-jest": "^29.0.0",
|
|
38
|
+
"typescript": "^5.0.0"
|
|
39
|
+
},
|
|
40
|
+
"publishConfig": {
|
|
41
|
+
"access": "public"
|
|
42
|
+
}
|
|
43
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { initTestDb, closeTestDb } from '../test-utils/db-utils';
|
|
2
|
+
|
|
3
|
+
declare global {
|
|
4
|
+
// eslint-disable-next-line no-var
|
|
5
|
+
var db: import('mongodb').Db;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
// Set up global mocks if needed
|
|
9
|
+
// global.fetch = jest.fn();
|
|
10
|
+
|
|
11
|
+
beforeEach(async () => {
|
|
12
|
+
global.db = await initTestDb();
|
|
13
|
+
}, 30_000);
|
|
14
|
+
|
|
15
|
+
afterEach(async () => {
|
|
16
|
+
await closeTestDb();
|
|
17
|
+
jest.resetAllMocks();
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
process.env.NODE_ENV = 'test';
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// TalkPilot DB exports
|
|
2
|
+
export * from './talkpilot';
|
|
3
|
+
|
|
4
|
+
export {
|
|
5
|
+
municipalDataMongodbClient,
|
|
6
|
+
getDb as getMunicipalDataDb,
|
|
7
|
+
setDb as setMunicipalDataDb,
|
|
8
|
+
ObjectId as MunicipalDataObjectId,
|
|
9
|
+
} from './municipal';
|
|
10
|
+
export * from './municipal/cities';
|
|
11
|
+
export * from './municipal/streets';
|
|
12
|
+
export * from './municipal/departmentsSubjects';
|
|
13
|
+
export * from './municipal/tickets';
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { municipalDataMongodbClient } from '../mongodb-client';
|
|
2
|
+
import { MongoClient } from 'mongodb';
|
|
3
|
+
|
|
4
|
+
describe('MunicipalDataMongoDBClient Validation', () => {
|
|
5
|
+
const originalEnv = process.env;
|
|
6
|
+
|
|
7
|
+
beforeEach(() => {
|
|
8
|
+
process.env = { ...originalEnv };
|
|
9
|
+
delete process.env.MONGO_URI;
|
|
10
|
+
delete process.env.MONGODB_URI;
|
|
11
|
+
|
|
12
|
+
// Force reset singleton state
|
|
13
|
+
(municipalDataMongodbClient as any).client = null;
|
|
14
|
+
(municipalDataMongodbClient as any).db = null;
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
afterAll(async () => {
|
|
18
|
+
process.env = originalEnv;
|
|
19
|
+
await municipalDataMongodbClient.disconnect();
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it('should succeed with default database name if only URI is provided', async () => {
|
|
23
|
+
const mockDb = { databaseName: 'municipal-data' };
|
|
24
|
+
const connectSpy = jest.spyOn(MongoClient.prototype, 'connect').mockResolvedValue({} as any);
|
|
25
|
+
const dbSpy = jest.spyOn(MongoClient.prototype, 'db').mockReturnValue(mockDb as any);
|
|
26
|
+
|
|
27
|
+
const validUri = 'mongodb://127.0.0.1:27017';
|
|
28
|
+
await municipalDataMongodbClient.connect(validUri);
|
|
29
|
+
|
|
30
|
+
expect(municipalDataMongodbClient.getDb()).toBeDefined();
|
|
31
|
+
expect(municipalDataMongodbClient.getDb().databaseName).toBe('municipal-data');
|
|
32
|
+
|
|
33
|
+
connectSpy.mockRestore();
|
|
34
|
+
dbSpy.mockRestore();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it('should allow overriding the default database name', async () => {
|
|
38
|
+
const mockDb = { databaseName: 'custom-municipal-db' };
|
|
39
|
+
const connectSpy = jest.spyOn(MongoClient.prototype, 'connect').mockResolvedValue({} as any);
|
|
40
|
+
const dbSpy = jest.spyOn(MongoClient.prototype, 'db').mockReturnValue(mockDb as any);
|
|
41
|
+
|
|
42
|
+
const validUri = 'mongodb://127.0.0.1:27017';
|
|
43
|
+
await municipalDataMongodbClient.connect(validUri, 'custom-municipal-db');
|
|
44
|
+
|
|
45
|
+
expect(municipalDataMongodbClient.getDb().databaseName).toBe('custom-municipal-db');
|
|
46
|
+
|
|
47
|
+
connectSpy.mockRestore();
|
|
48
|
+
dbSpy.mockRestore();
|
|
49
|
+
});
|
|
50
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { getDb, ObjectId, City } from '../index';
|
|
2
|
+
import { Collection, Filter, ObjectId as MongoObjectId } from 'mongodb';
|
|
3
|
+
|
|
4
|
+
export const getCitiesCollection = (): Collection<City> => {
|
|
5
|
+
return getDb().collection<City>('cities');
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
export const findCities = async (filter: Filter<City> = {}): Promise<City[]> => {
|
|
9
|
+
return await getCitiesCollection().find(filter).toArray();
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const getCityById = async (cityId: string): Promise<City | null> => {
|
|
13
|
+
const city = await getCitiesCollection().findOne({ _id: new ObjectId(cityId) });
|
|
14
|
+
return city ? city : null;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export const createCity = async (
|
|
18
|
+
cityData: Omit<City, '_id' | 'createdAt' | 'updatedAt'>
|
|
19
|
+
): Promise<MongoObjectId> => {
|
|
20
|
+
const city: Omit<City, '_id'> = {
|
|
21
|
+
...cityData,
|
|
22
|
+
createdAt: new Date(),
|
|
23
|
+
updatedAt: new Date(),
|
|
24
|
+
};
|
|
25
|
+
const { insertedId } = await getCitiesCollection().insertOne(city as City);
|
|
26
|
+
return insertedId;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export const updateCity = async (
|
|
30
|
+
cityId: string,
|
|
31
|
+
data: Partial<Omit<City, '_id' | 'createdAt' | 'updatedAt'>>
|
|
32
|
+
): Promise<City | null> => {
|
|
33
|
+
const result = await getCitiesCollection().findOneAndUpdate(
|
|
34
|
+
{ _id: new ObjectId(cityId) },
|
|
35
|
+
{ $set: { ...data, updatedAt: new Date() } },
|
|
36
|
+
{ returnDocument: 'after' }
|
|
37
|
+
);
|
|
38
|
+
return result || null;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export const deleteCity = async (cityId: string): Promise<boolean> => {
|
|
42
|
+
const result = await getCitiesCollection().deleteOne({ _id: new ObjectId(cityId) });
|
|
43
|
+
return result.deletedCount > 0;
|
|
44
|
+
};
|