@talkpilot/core-db 1.1.18 → 1.2.0
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 -65
- package/DEVELOPMENT.md +98 -98
- package/README.md +160 -160
- package/dist/talkpilot/calls/calls.getters.d.ts +2 -1
- package/dist/talkpilot/calls/calls.getters.d.ts.map +1 -1
- package/dist/talkpilot/calls/calls.getters.js +176 -0
- package/dist/talkpilot/calls/calls.getters.js.map +1 -1
- package/dist/talkpilot/calls/calls.types.d.ts +49 -2
- package/dist/talkpilot/calls/calls.types.d.ts.map +1 -1
- package/dist/talkpilot/calls/calls.types.js.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts +1 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js +13 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.getters.js.map +1 -1
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts +2 -0
- package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts.map +1 -1
- package/jest.config.js +19 -19
- package/package.json +45 -45
- package/src/__tests__/setup.ts +20 -20
- package/src/connection.ts +42 -42
- package/src/index.ts +16 -16
- package/src/municipal/__tests__/validation.spec.ts +62 -62
- package/src/municipal/cities/cities.getters.ts +50 -50
- package/src/municipal/cities/cities.types.ts +11 -11
- package/src/municipal/cities/index.ts +2 -2
- package/src/municipal/departmentsSubjects/departmentsSubjects.getters.ts +282 -282
- package/src/municipal/departmentsSubjects/departmentsSubjects.types.ts +72 -72
- package/src/municipal/departmentsSubjects/index.ts +9 -9
- package/src/municipal/index.ts +21 -21
- package/src/municipal/mongodb-client.ts +61 -61
- package/src/municipal/streets/index.ts +2 -2
- package/src/municipal/streets/streets.getters.ts +125 -125
- package/src/municipal/streets/streets.types.ts +18 -18
- package/src/municipal/systemInstructions/__tests__/getters.spec.ts +113 -113
- package/src/municipal/systemInstructions/__tests__/setters.spec.ts +274 -274
- package/src/municipal/systemInstructions/index.ts +7 -7
- package/src/municipal/systemInstructions/instructions.getters.ts +57 -57
- package/src/municipal/systemInstructions/instructions.setters.ts +119 -119
- package/src/municipal/systemInstructions/instructions.types.ts +30 -30
- package/src/municipal/tickets/__tests__/tickets.getters.spec.ts +66 -66
- package/src/municipal/tickets/index.ts +2 -2
- package/src/municipal/tickets/tickets.getters.ts +261 -261
- package/src/municipal/tickets/tickets.types.ts +43 -43
- package/src/municipal/utils/types.ts +11 -11
- package/src/talkpilot/__tests__/db.spec.ts +38 -38
- package/src/talkpilot/__tests__/mongodb-client.spec.ts +18 -18
- package/src/talkpilot/__tests__/validation.spec.ts +68 -68
- package/src/talkpilot/agents/__tests__/agents.getters.spec.ts +29 -29
- package/src/talkpilot/agents/agents.getters.ts +34 -34
- package/src/talkpilot/agents/agents.types.ts +14 -14
- package/src/talkpilot/agents/index.ts +2 -2
- package/src/talkpilot/backgroundToolResults/__tests__/backgroundToolResults.getters.spec.ts +147 -147
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.getters.ts +65 -65
- package/src/talkpilot/backgroundToolResults/backgroundToolResults.types.ts +23 -23
- package/src/talkpilot/backgroundToolResults/index.ts +2 -2
- package/src/talkpilot/calls/__tests__/callStats.utils.spec.ts +128 -128
- package/src/talkpilot/calls/__tests__/calls.spec.ts +252 -252
- package/src/talkpilot/calls/calls.getters.ts +446 -248
- package/src/talkpilot/calls/calls.types.ts +171 -116
- package/src/talkpilot/calls/index.ts +2 -2
- package/src/talkpilot/clientAudioBuffers/__tests__/clientAudioBuffer.getters.spec.ts +160 -160
- package/src/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.ts +117 -117
- package/src/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.ts +25 -25
- package/src/talkpilot/clientAudioBuffers/index.ts +2 -2
- package/src/talkpilot/clients/clients.getters.ts +16 -16
- package/src/talkpilot/clients/clients.types.ts +14 -14
- package/src/talkpilot/clients/index.ts +2 -2
- package/src/talkpilot/clientsConfig/__tests__/clientsConfig.spec.ts +106 -106
- package/src/talkpilot/clientsConfig/clientsConfig.getters.ts +44 -22
- package/src/talkpilot/clientsConfig/clientsConfig.types.ts +94 -92
- package/src/talkpilot/clientsConfig/index.ts +2 -2
- package/src/talkpilot/flows/__tests__/flows.schema.spec.ts +67 -67
- package/src/talkpilot/flows/flows.getter.ts +14 -14
- package/src/talkpilot/flows/flows.schema.ts +153 -153
- package/src/talkpilot/flows/flows.types.ts +184 -184
- package/src/talkpilot/flows/index.ts +2 -2
- package/src/talkpilot/groups/__tests__/groups.spec.ts +90 -90
- package/src/talkpilot/groups/__tests__/phone.utils.spec.ts +32 -32
- package/src/talkpilot/groups/groups.getters.ts +30 -30
- package/src/talkpilot/groups/groups.types.ts +29 -29
- package/src/talkpilot/groups/index.ts +3 -3
- package/src/talkpilot/groups/phone.utils.ts +46 -46
- package/src/talkpilot/index.ts +29 -29
- package/src/talkpilot/leads/index.ts +2 -2
- package/src/talkpilot/leads/leads.getter.ts +6 -6
- package/src/talkpilot/leads/leads.schema.ts +33 -33
- package/src/talkpilot/leads/leads.types.ts +20 -20
- package/src/talkpilot/mongodb-client.ts +78 -78
- package/src/talkpilot/phone_numbers/__tests__/phone_numbers.spec.ts +247 -247
- package/src/talkpilot/phone_numbers/index.ts +2 -2
- package/src/talkpilot/phone_numbers/phone_numbers.getter.ts +154 -154
- package/src/talkpilot/phone_numbers/phone_numbers.schema.ts +17 -17
- package/src/talkpilot/phone_numbers/phone_numbers.types.ts +30 -30
- package/src/talkpilot/plans/__tests__/plans.spec.ts +70 -70
- package/src/talkpilot/plans/index.ts +2 -2
- package/src/talkpilot/plans/plans.getters.ts +132 -132
- package/src/talkpilot/plans/plans.types.ts +89 -89
- package/src/talkpilot/results/index.ts +7 -7
- package/src/talkpilot/results/results.getter.ts +35 -35
- package/src/talkpilot/results/results.schema.ts +25 -25
- package/src/talkpilot/results/results.types.ts +34 -34
- package/src/talkpilot/retry_analyze/__tests__/retryAnalyze.getters.spec.ts +156 -156
- package/src/talkpilot/retry_analyze/index.ts +2 -2
- package/src/talkpilot/retry_analyze/retryAnalyze.getters.ts +75 -75
- package/src/talkpilot/retry_analyze/retryAnalyze.types.ts +13 -13
- package/src/talkpilot/sessions/__tests__/sessions.spec.ts +147 -147
- package/src/talkpilot/sessions/index.ts +2 -2
- package/src/talkpilot/sessions/sessions.getter.ts +92 -92
- package/src/talkpilot/sessions/sessions.schema.ts +34 -34
- package/src/talkpilot/sessions/sessions.types.ts +30 -30
- package/src/talkpilot/subscriptions/__tests__/subscriptions.getters.utils.spec.ts +45 -45
- package/src/talkpilot/subscriptions/index.ts +3 -3
- package/src/talkpilot/subscriptions/subscriptions.getters.ts +146 -146
- package/src/talkpilot/subscriptions/subscriptions.getters.utils.ts +33 -33
- package/src/talkpilot/subscriptions/subscriptions.types.ts +66 -66
- package/src/talkpilot/utils/__tests__/query.utils.spec.ts +49 -49
- package/src/talkpilot/utils/query.utils.ts +21 -21
- package/src/test-utils/db-utils.ts +24 -24
- package/src/test-utils/factories/index.ts +12 -12
- package/src/test-utils/factories/municipal/cities.ts +16 -16
- package/src/test-utils/factories/municipal/departmentsSubjects.ts +37 -37
- package/src/test-utils/factories/municipal/streets.ts +22 -22
- package/src/test-utils/factories/municipal/tickets.ts +39 -39
- package/src/test-utils/factories/talkpilot/agents.ts +19 -19
- package/src/test-utils/factories/talkpilot/calls.ts +37 -37
- package/src/test-utils/factories/talkpilot/clientAudioBuffers.ts +20 -20
- package/src/test-utils/factories/talkpilot/clientsConfig.ts +18 -18
- package/src/test-utils/factories/talkpilot/flows.ts +33 -33
- package/src/test-utils/factories/talkpilot/groups.ts +33 -33
- package/src/test-utils/factories/talkpilot/phone_numbers.ts +22 -22
- package/src/test-utils/factories/talkpilot/sessions.ts +35 -35
- package/src/utils/validation.ts +23 -23
- package/tsconfig.json +23 -23
|
@@ -1,128 +1,128 @@
|
|
|
1
|
-
import {
|
|
2
|
-
addDays,
|
|
3
|
-
countCallsByPhoneInRange,
|
|
4
|
-
range,
|
|
5
|
-
startOfDay,
|
|
6
|
-
getCallsCollection,
|
|
7
|
-
} from "../calls.getters";
|
|
8
|
-
import {
|
|
9
|
-
createIncomingCallDoc,
|
|
10
|
-
createOutGoingCallDoc,
|
|
11
|
-
} from "../../../test-utils/factories";
|
|
12
|
-
|
|
13
|
-
describe("callStats.utils", () => {
|
|
14
|
-
describe("countCallsByPhoneInRange", () => {
|
|
15
|
-
it("counts outgoing calls for a phone within a date range", async () => {
|
|
16
|
-
const phone = "+972500000001";
|
|
17
|
-
const baseDate = new Date("2023-01-10T10:00:00Z");
|
|
18
|
-
|
|
19
|
-
const outgoingInside = createOutGoingCallDoc({
|
|
20
|
-
customerPhoneNumber: phone,
|
|
21
|
-
createdAt: addDays(baseDate, 0),
|
|
22
|
-
});
|
|
23
|
-
const outgoingOutsideBefore = createOutGoingCallDoc({
|
|
24
|
-
customerPhoneNumber: phone,
|
|
25
|
-
createdAt: addDays(baseDate, -2),
|
|
26
|
-
});
|
|
27
|
-
const outgoingOutsideAfter = createOutGoingCallDoc({
|
|
28
|
-
customerPhoneNumber: phone,
|
|
29
|
-
createdAt: addDays(baseDate, 2),
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
await getCallsCollection().insertMany([
|
|
33
|
-
{ ...outgoingInside, updatedAt: outgoingInside.createdAt, env: "test" },
|
|
34
|
-
{
|
|
35
|
-
...outgoingOutsideBefore,
|
|
36
|
-
updatedAt: outgoingOutsideBefore.createdAt,
|
|
37
|
-
env: "test",
|
|
38
|
-
},
|
|
39
|
-
{
|
|
40
|
-
...outgoingOutsideAfter,
|
|
41
|
-
updatedAt: outgoingOutsideAfter.createdAt,
|
|
42
|
-
env: "test",
|
|
43
|
-
},
|
|
44
|
-
]);
|
|
45
|
-
|
|
46
|
-
const since = addDays(baseDate, -1);
|
|
47
|
-
const until = addDays(baseDate, 1);
|
|
48
|
-
|
|
49
|
-
const count = await countCallsByPhoneInRange(
|
|
50
|
-
phone,
|
|
51
|
-
{ isOutgoingCall: true },
|
|
52
|
-
{ since, until },
|
|
53
|
-
);
|
|
54
|
-
|
|
55
|
-
expect(count).toBe(1);
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
it("filters by incoming/outgoing flags", async () => {
|
|
59
|
-
const phone = "+972500000002";
|
|
60
|
-
const createdAt = new Date("2023-02-01T12:00:00Z");
|
|
61
|
-
|
|
62
|
-
const outgoing = createOutGoingCallDoc({
|
|
63
|
-
customerPhoneNumber: phone,
|
|
64
|
-
createdAt,
|
|
65
|
-
});
|
|
66
|
-
const incoming = createIncomingCallDoc({
|
|
67
|
-
customerPhoneNumber: phone,
|
|
68
|
-
createdAt,
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
await getCallsCollection().insertMany([
|
|
72
|
-
{ ...outgoing, updatedAt: outgoing.createdAt, env: "test" },
|
|
73
|
-
{ ...incoming, updatedAt: incoming.createdAt, env: "test" },
|
|
74
|
-
]);
|
|
75
|
-
|
|
76
|
-
const outgoingCount = await countCallsByPhoneInRange(
|
|
77
|
-
phone,
|
|
78
|
-
{ isOutgoingCall: true },
|
|
79
|
-
range.between(addDays(createdAt, -1), addDays(createdAt, 1)),
|
|
80
|
-
);
|
|
81
|
-
const incomingCount = await countCallsByPhoneInRange(
|
|
82
|
-
phone,
|
|
83
|
-
{ isIncomingCall: true },
|
|
84
|
-
range.between(addDays(createdAt, -1), addDays(createdAt, 1)),
|
|
85
|
-
);
|
|
86
|
-
|
|
87
|
-
expect(outgoingCount).toBe(1);
|
|
88
|
-
expect(incomingCount).toBe(1);
|
|
89
|
-
});
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
describe("date helpers", () => {
|
|
93
|
-
it("startOfDay normalizes to midnight", () => {
|
|
94
|
-
const d = new Date("2023-03-10T15:30:45.000Z");
|
|
95
|
-
const s = startOfDay(d);
|
|
96
|
-
expect(s.getUTCHours()).toBe(0);
|
|
97
|
-
expect(s.getUTCMinutes()).toBe(0);
|
|
98
|
-
expect(s.getUTCSeconds()).toBe(0);
|
|
99
|
-
expect(s.getUTCMilliseconds()).toBe(0);
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
it("addDays shifts the date by given days", () => {
|
|
103
|
-
const d = new Date("2023-03-10T00:00:00.000Z");
|
|
104
|
-
expect(addDays(d, 1).getUTCDate()).toBe(11);
|
|
105
|
-
expect(addDays(d, -1).getUTCDate()).toBe(9);
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it("range helpers produce expected bounds", () => {
|
|
109
|
-
const base = new Date("2023-03-15T10:00:00.000Z");
|
|
110
|
-
|
|
111
|
-
const betweenRange = range.between(addDays(base, -1), addDays(base, 1));
|
|
112
|
-
expect(betweenRange.since).toEqual(addDays(base, -1));
|
|
113
|
-
expect(betweenRange.until).toEqual(addDays(base, 1));
|
|
114
|
-
|
|
115
|
-
const yesterdayRange = range.yesterday();
|
|
116
|
-
expect(yesterdayRange.since).toBeInstanceOf(Date);
|
|
117
|
-
expect(yesterdayRange.until).toBeInstanceOf(Date);
|
|
118
|
-
|
|
119
|
-
const todayFullRange = range.todayFull();
|
|
120
|
-
expect(todayFullRange.since).toBeInstanceOf(Date);
|
|
121
|
-
expect(todayFullRange.until).toBeInstanceOf(Date);
|
|
122
|
-
|
|
123
|
-
const startToNowRange = range.startOfDayToNow(base);
|
|
124
|
-
expect(startToNowRange.since).toEqual(startOfDay(base));
|
|
125
|
-
expect(startToNowRange.until).toBeInstanceOf(Date);
|
|
126
|
-
});
|
|
127
|
-
});
|
|
128
|
-
});
|
|
1
|
+
import {
|
|
2
|
+
addDays,
|
|
3
|
+
countCallsByPhoneInRange,
|
|
4
|
+
range,
|
|
5
|
+
startOfDay,
|
|
6
|
+
getCallsCollection,
|
|
7
|
+
} from "../calls.getters";
|
|
8
|
+
import {
|
|
9
|
+
createIncomingCallDoc,
|
|
10
|
+
createOutGoingCallDoc,
|
|
11
|
+
} from "../../../test-utils/factories";
|
|
12
|
+
|
|
13
|
+
describe("callStats.utils", () => {
|
|
14
|
+
describe("countCallsByPhoneInRange", () => {
|
|
15
|
+
it("counts outgoing calls for a phone within a date range", async () => {
|
|
16
|
+
const phone = "+972500000001";
|
|
17
|
+
const baseDate = new Date("2023-01-10T10:00:00Z");
|
|
18
|
+
|
|
19
|
+
const outgoingInside = createOutGoingCallDoc({
|
|
20
|
+
customerPhoneNumber: phone,
|
|
21
|
+
createdAt: addDays(baseDate, 0),
|
|
22
|
+
});
|
|
23
|
+
const outgoingOutsideBefore = createOutGoingCallDoc({
|
|
24
|
+
customerPhoneNumber: phone,
|
|
25
|
+
createdAt: addDays(baseDate, -2),
|
|
26
|
+
});
|
|
27
|
+
const outgoingOutsideAfter = createOutGoingCallDoc({
|
|
28
|
+
customerPhoneNumber: phone,
|
|
29
|
+
createdAt: addDays(baseDate, 2),
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
await getCallsCollection().insertMany([
|
|
33
|
+
{ ...outgoingInside, updatedAt: outgoingInside.createdAt, env: "test" },
|
|
34
|
+
{
|
|
35
|
+
...outgoingOutsideBefore,
|
|
36
|
+
updatedAt: outgoingOutsideBefore.createdAt,
|
|
37
|
+
env: "test",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
...outgoingOutsideAfter,
|
|
41
|
+
updatedAt: outgoingOutsideAfter.createdAt,
|
|
42
|
+
env: "test",
|
|
43
|
+
},
|
|
44
|
+
]);
|
|
45
|
+
|
|
46
|
+
const since = addDays(baseDate, -1);
|
|
47
|
+
const until = addDays(baseDate, 1);
|
|
48
|
+
|
|
49
|
+
const count = await countCallsByPhoneInRange(
|
|
50
|
+
phone,
|
|
51
|
+
{ isOutgoingCall: true },
|
|
52
|
+
{ since, until },
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
expect(count).toBe(1);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("filters by incoming/outgoing flags", async () => {
|
|
59
|
+
const phone = "+972500000002";
|
|
60
|
+
const createdAt = new Date("2023-02-01T12:00:00Z");
|
|
61
|
+
|
|
62
|
+
const outgoing = createOutGoingCallDoc({
|
|
63
|
+
customerPhoneNumber: phone,
|
|
64
|
+
createdAt,
|
|
65
|
+
});
|
|
66
|
+
const incoming = createIncomingCallDoc({
|
|
67
|
+
customerPhoneNumber: phone,
|
|
68
|
+
createdAt,
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
await getCallsCollection().insertMany([
|
|
72
|
+
{ ...outgoing, updatedAt: outgoing.createdAt, env: "test" },
|
|
73
|
+
{ ...incoming, updatedAt: incoming.createdAt, env: "test" },
|
|
74
|
+
]);
|
|
75
|
+
|
|
76
|
+
const outgoingCount = await countCallsByPhoneInRange(
|
|
77
|
+
phone,
|
|
78
|
+
{ isOutgoingCall: true },
|
|
79
|
+
range.between(addDays(createdAt, -1), addDays(createdAt, 1)),
|
|
80
|
+
);
|
|
81
|
+
const incomingCount = await countCallsByPhoneInRange(
|
|
82
|
+
phone,
|
|
83
|
+
{ isIncomingCall: true },
|
|
84
|
+
range.between(addDays(createdAt, -1), addDays(createdAt, 1)),
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
expect(outgoingCount).toBe(1);
|
|
88
|
+
expect(incomingCount).toBe(1);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe("date helpers", () => {
|
|
93
|
+
it("startOfDay normalizes to midnight", () => {
|
|
94
|
+
const d = new Date("2023-03-10T15:30:45.000Z");
|
|
95
|
+
const s = startOfDay(d);
|
|
96
|
+
expect(s.getUTCHours()).toBe(0);
|
|
97
|
+
expect(s.getUTCMinutes()).toBe(0);
|
|
98
|
+
expect(s.getUTCSeconds()).toBe(0);
|
|
99
|
+
expect(s.getUTCMilliseconds()).toBe(0);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
it("addDays shifts the date by given days", () => {
|
|
103
|
+
const d = new Date("2023-03-10T00:00:00.000Z");
|
|
104
|
+
expect(addDays(d, 1).getUTCDate()).toBe(11);
|
|
105
|
+
expect(addDays(d, -1).getUTCDate()).toBe(9);
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
it("range helpers produce expected bounds", () => {
|
|
109
|
+
const base = new Date("2023-03-15T10:00:00.000Z");
|
|
110
|
+
|
|
111
|
+
const betweenRange = range.between(addDays(base, -1), addDays(base, 1));
|
|
112
|
+
expect(betweenRange.since).toEqual(addDays(base, -1));
|
|
113
|
+
expect(betweenRange.until).toEqual(addDays(base, 1));
|
|
114
|
+
|
|
115
|
+
const yesterdayRange = range.yesterday();
|
|
116
|
+
expect(yesterdayRange.since).toBeInstanceOf(Date);
|
|
117
|
+
expect(yesterdayRange.until).toBeInstanceOf(Date);
|
|
118
|
+
|
|
119
|
+
const todayFullRange = range.todayFull();
|
|
120
|
+
expect(todayFullRange.since).toBeInstanceOf(Date);
|
|
121
|
+
expect(todayFullRange.until).toBeInstanceOf(Date);
|
|
122
|
+
|
|
123
|
+
const startToNowRange = range.startOfDayToNow(base);
|
|
124
|
+
expect(startToNowRange.since).toEqual(startOfDay(base));
|
|
125
|
+
expect(startToNowRange.until).toBeInstanceOf(Date);
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
});
|