@talkpilot/core-db 1.2.0 → 1.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (168) hide show
  1. package/README.md +95 -116
  2. package/README_OLD.md +160 -0
  3. package/dist/talkpilot/calls/calls.dashboard.d.ts +3 -0
  4. package/dist/talkpilot/calls/calls.dashboard.d.ts.map +1 -0
  5. package/dist/talkpilot/calls/calls.dashboard.js +191 -0
  6. package/dist/talkpilot/calls/calls.dashboard.js.map +1 -0
  7. package/dist/talkpilot/calls/calls.getters.d.ts +3 -3
  8. package/dist/talkpilot/calls/calls.getters.d.ts.map +1 -1
  9. package/dist/talkpilot/calls/calls.getters.js +1 -178
  10. package/dist/talkpilot/calls/calls.getters.js.map +1 -1
  11. package/dist/talkpilot/calls/calls.types.d.ts +3 -55
  12. package/dist/talkpilot/calls/calls.types.d.ts.map +1 -1
  13. package/dist/talkpilot/calls/dashboard/calls.dashboard.d.ts +36 -0
  14. package/dist/talkpilot/calls/dashboard/calls.dashboard.d.ts.map +1 -0
  15. package/dist/talkpilot/calls/dashboard/calls.dashboard.js +208 -0
  16. package/dist/talkpilot/calls/dashboard/calls.dashboard.js.map +1 -0
  17. package/dist/talkpilot/calls/dashboard/calls.dashboard.types.d.ts +66 -0
  18. package/dist/talkpilot/calls/dashboard/calls.dashboard.types.d.ts.map +1 -0
  19. package/dist/talkpilot/calls/dashboard/calls.dashboard.types.js +3 -0
  20. package/dist/talkpilot/calls/dashboard/calls.dashboard.types.js.map +1 -0
  21. package/dist/talkpilot/calls/index.d.ts +1 -0
  22. package/dist/talkpilot/calls/index.d.ts.map +1 -1
  23. package/dist/talkpilot/calls/index.js +1 -0
  24. package/dist/talkpilot/calls/index.js.map +1 -1
  25. package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts +2 -2
  26. package/dist/talkpilot/clientsConfig/clientsConfig.getters.d.ts.map +1 -1
  27. package/dist/talkpilot/clientsConfig/clientsConfig.getters.js +11 -10
  28. package/dist/talkpilot/clientsConfig/clientsConfig.getters.js.map +1 -1
  29. package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts +20 -9
  30. package/dist/talkpilot/clientsConfig/clientsConfig.types.d.ts.map +1 -1
  31. package/dist/talkpilot/clientsConfig/clientsConfig.types.js +6 -0
  32. package/dist/talkpilot/clientsConfig/clientsConfig.types.js.map +1 -1
  33. package/dist/talkpilot/flows/flows.schema.js +1 -1
  34. package/dist/talkpilot/phone_numbers/index.d.ts +2 -2
  35. package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts +1 -1
  36. package/dist/talkpilot/phone_numbers/phone_numbers.getter.d.ts.map +1 -1
  37. package/dist/talkpilot/phone_numbers/phone_numbers.getter.js +5 -3
  38. package/dist/talkpilot/phone_numbers/phone_numbers.getter.js.map +1 -1
  39. package/dist/talkpilot/phone_numbers/phone_numbers.schema.js +12 -12
  40. package/dist/talkpilot/phone_numbers/phone_numbers.types.d.ts +4 -4
  41. package/dist/talkpilot/results/results.getter.d.ts.map +1 -1
  42. package/dist/talkpilot/results/results.getter.js.map +1 -1
  43. package/dist/talkpilot/retry_analyze/retryAnalyze.getters.d.ts.map +1 -1
  44. package/dist/talkpilot/retry_analyze/retryAnalyze.getters.js.map +1 -1
  45. package/dist/utils/shared.types.d.ts +5 -0
  46. package/dist/utils/shared.types.d.ts.map +1 -0
  47. package/dist/utils/shared.types.js +3 -0
  48. package/dist/utils/shared.types.js.map +1 -0
  49. package/package.json +2 -1
  50. package/src/__tests__/setup.ts +20 -20
  51. package/src/connection.ts +42 -42
  52. package/src/index.ts +16 -16
  53. package/src/municipal/__tests__/validation.spec.ts +62 -62
  54. package/src/municipal/cities/cities.getters.ts +50 -50
  55. package/src/municipal/cities/cities.types.ts +11 -11
  56. package/src/municipal/cities/index.ts +2 -2
  57. package/src/municipal/departmentsSubjects/departmentsSubjects.getters.ts +282 -282
  58. package/src/municipal/departmentsSubjects/departmentsSubjects.types.ts +72 -72
  59. package/src/municipal/departmentsSubjects/index.ts +9 -9
  60. package/src/municipal/index.ts +21 -21
  61. package/src/municipal/mongodb-client.ts +61 -61
  62. package/src/municipal/streets/index.ts +2 -2
  63. package/src/municipal/streets/streets.getters.ts +125 -125
  64. package/src/municipal/streets/streets.types.ts +18 -18
  65. package/src/municipal/systemInstructions/__tests__/getters.spec.ts +113 -113
  66. package/src/municipal/systemInstructions/__tests__/setters.spec.ts +274 -274
  67. package/src/municipal/systemInstructions/index.ts +7 -7
  68. package/src/municipal/systemInstructions/instructions.getters.ts +57 -57
  69. package/src/municipal/systemInstructions/instructions.setters.ts +119 -119
  70. package/src/municipal/systemInstructions/instructions.types.ts +30 -30
  71. package/src/municipal/tickets/__tests__/tickets.getters.spec.ts +66 -66
  72. package/src/municipal/tickets/index.ts +2 -2
  73. package/src/municipal/tickets/tickets.getters.ts +261 -261
  74. package/src/municipal/tickets/tickets.types.ts +43 -43
  75. package/src/municipal/utils/types.ts +11 -11
  76. package/src/talkpilot/__tests__/db.spec.ts +38 -38
  77. package/src/talkpilot/__tests__/mongodb-client.spec.ts +18 -18
  78. package/src/talkpilot/__tests__/validation.spec.ts +68 -68
  79. package/src/talkpilot/agents/__tests__/agents.getters.spec.ts +29 -29
  80. package/src/talkpilot/agents/agents.getters.ts +34 -34
  81. package/src/talkpilot/agents/agents.types.ts +14 -14
  82. package/src/talkpilot/agents/index.ts +2 -2
  83. package/src/talkpilot/backgroundToolResults/__tests__/backgroundToolResults.getters.spec.ts +147 -147
  84. package/src/talkpilot/backgroundToolResults/backgroundToolResults.getters.ts +65 -65
  85. package/src/talkpilot/backgroundToolResults/backgroundToolResults.types.ts +23 -23
  86. package/src/talkpilot/backgroundToolResults/index.ts +2 -2
  87. package/src/talkpilot/calls/__tests__/callStats.utils.spec.ts +128 -128
  88. package/src/talkpilot/calls/__tests__/calls.dashboard.spec.ts +46 -0
  89. package/src/talkpilot/calls/__tests__/calls.spec.ts +270 -252
  90. package/src/talkpilot/calls/calls.getters.ts +248 -446
  91. package/src/talkpilot/calls/calls.types.ts +113 -171
  92. package/src/talkpilot/calls/dashboard/calls.dashboard.ts +243 -0
  93. package/src/talkpilot/calls/dashboard/calls.dashboard.types.ts +70 -0
  94. package/src/talkpilot/calls/index.ts +3 -2
  95. package/src/talkpilot/clientAudioBuffers/__tests__/clientAudioBuffer.getters.spec.ts +160 -160
  96. package/src/talkpilot/clientAudioBuffers/clientAudioBuffer.getters.ts +117 -117
  97. package/src/talkpilot/clientAudioBuffers/clientsAudioBuffers.types.ts +25 -25
  98. package/src/talkpilot/clientAudioBuffers/index.ts +2 -2
  99. package/src/talkpilot/clients/clients.getters.ts +16 -16
  100. package/src/talkpilot/clients/clients.types.ts +14 -14
  101. package/src/talkpilot/clients/index.ts +2 -2
  102. package/src/talkpilot/clientsConfig/__tests__/clientsConfig.getters.spec.ts +53 -0
  103. package/src/talkpilot/clientsConfig/__tests__/clientsConfig.spec.ts +197 -106
  104. package/src/talkpilot/clientsConfig/clientsConfig.getters.ts +55 -44
  105. package/src/talkpilot/clientsConfig/clientsConfig.types.ts +127 -94
  106. package/src/talkpilot/clientsConfig/index.ts +2 -2
  107. package/src/talkpilot/flows/__tests__/flows.schema.spec.ts +71 -67
  108. package/src/talkpilot/flows/flows.getter.ts +14 -14
  109. package/src/talkpilot/flows/flows.schema.ts +153 -153
  110. package/src/talkpilot/flows/flows.types.ts +184 -184
  111. package/src/talkpilot/flows/index.ts +2 -2
  112. package/src/talkpilot/groups/__tests__/groups.spec.ts +90 -90
  113. package/src/talkpilot/groups/__tests__/phone.utils.spec.ts +32 -32
  114. package/src/talkpilot/groups/groups.getters.ts +30 -30
  115. package/src/talkpilot/groups/groups.types.ts +29 -29
  116. package/src/talkpilot/groups/index.ts +3 -3
  117. package/src/talkpilot/groups/phone.utils.ts +46 -46
  118. package/src/talkpilot/index.ts +29 -29
  119. package/src/talkpilot/leads/index.ts +2 -2
  120. package/src/talkpilot/leads/leads.getter.ts +6 -6
  121. package/src/talkpilot/leads/leads.schema.ts +33 -33
  122. package/src/talkpilot/leads/leads.types.ts +20 -20
  123. package/src/talkpilot/mongodb-client.ts +78 -78
  124. package/src/talkpilot/phone_numbers/__tests__/phone_numbers.spec.ts +252 -247
  125. package/src/talkpilot/phone_numbers/index.ts +2 -2
  126. package/src/talkpilot/phone_numbers/phone_numbers.getter.ts +158 -154
  127. package/src/talkpilot/phone_numbers/phone_numbers.schema.ts +17 -17
  128. package/src/talkpilot/phone_numbers/phone_numbers.types.ts +30 -30
  129. package/src/talkpilot/plans/__tests__/plans.spec.ts +70 -70
  130. package/src/talkpilot/plans/index.ts +2 -2
  131. package/src/talkpilot/plans/plans.getters.ts +132 -132
  132. package/src/talkpilot/plans/plans.types.ts +89 -89
  133. package/src/talkpilot/results/index.ts +7 -7
  134. package/src/talkpilot/results/results.getter.ts +39 -35
  135. package/src/talkpilot/results/results.schema.ts +25 -25
  136. package/src/talkpilot/results/results.types.ts +34 -34
  137. package/src/talkpilot/retry_analyze/__tests__/retryAnalyze.getters.spec.ts +156 -156
  138. package/src/talkpilot/retry_analyze/index.ts +2 -2
  139. package/src/talkpilot/retry_analyze/retryAnalyze.getters.ts +84 -75
  140. package/src/talkpilot/retry_analyze/retryAnalyze.types.ts +13 -13
  141. package/src/talkpilot/sessions/__tests__/sessions.spec.ts +147 -147
  142. package/src/talkpilot/sessions/index.ts +2 -2
  143. package/src/talkpilot/sessions/sessions.getter.ts +92 -92
  144. package/src/talkpilot/sessions/sessions.schema.ts +34 -34
  145. package/src/talkpilot/sessions/sessions.types.ts +30 -30
  146. package/src/talkpilot/subscriptions/__tests__/subscriptions.getters.utils.spec.ts +45 -45
  147. package/src/talkpilot/subscriptions/index.ts +3 -3
  148. package/src/talkpilot/subscriptions/subscriptions.getters.ts +146 -146
  149. package/src/talkpilot/subscriptions/subscriptions.getters.utils.ts +33 -33
  150. package/src/talkpilot/subscriptions/subscriptions.types.ts +66 -66
  151. package/src/talkpilot/utils/__tests__/query.utils.spec.ts +49 -49
  152. package/src/talkpilot/utils/query.utils.ts +21 -21
  153. package/src/test-utils/db-utils.ts +24 -24
  154. package/src/test-utils/factories/index.ts +12 -12
  155. package/src/test-utils/factories/municipal/cities.ts +16 -16
  156. package/src/test-utils/factories/municipal/departmentsSubjects.ts +37 -37
  157. package/src/test-utils/factories/municipal/streets.ts +22 -22
  158. package/src/test-utils/factories/municipal/tickets.ts +39 -39
  159. package/src/test-utils/factories/talkpilot/agents.ts +19 -19
  160. package/src/test-utils/factories/talkpilot/calls.ts +37 -37
  161. package/src/test-utils/factories/talkpilot/clientAudioBuffers.ts +20 -20
  162. package/src/test-utils/factories/talkpilot/clientsConfig.ts +18 -18
  163. package/src/test-utils/factories/talkpilot/flows.ts +33 -33
  164. package/src/test-utils/factories/talkpilot/groups.ts +33 -33
  165. package/src/test-utils/factories/talkpilot/phone_numbers.ts +22 -22
  166. package/src/test-utils/factories/talkpilot/sessions.ts +35 -35
  167. package/src/utils/shared.types.ts +4 -0
  168. package/src/utils/validation.ts +23 -23
@@ -1,132 +1,132 @@
1
- import {
2
- getDb,
3
- Plan,
4
- PlanDoc,
5
- PlanFilter,
6
- PlanQueryOptions,
7
- SimplePlanFilter,
8
- } from "../index";
9
- import { Filter, ObjectId } from "mongodb";
10
- import { applyQueryOptions } from "../utils/query.utils";
11
-
12
- export const getPlansCollection = () => {
13
- return getDb().collection<Plan>("plans");
14
- };
15
-
16
- /**
17
- * Converts a simple filter to MongoDB query format
18
- */
19
- const buildSimpleQuery = (filter: SimplePlanFilter): Filter<Plan> => {
20
- const query: Filter<Plan> = {};
21
-
22
- if (filter._id) {
23
- query._id = new ObjectId(filter._id);
24
- }
25
- if (filter.productKey !== undefined) {
26
- query.productKey = filter.productKey;
27
- }
28
- if (filter.isActive !== undefined) {
29
- query.isActive = filter.isActive;
30
- }
31
- if (filter.currency !== undefined) {
32
- query.currency = filter.currency;
33
- }
34
- if (filter.region !== undefined) {
35
- query.region = filter.region;
36
- }
37
- if (filter.countryCode !== undefined) {
38
- query.countryCode = filter.countryCode;
39
- }
40
- if (filter.originalPlanId !== undefined) {
41
- query.originalPlanId = filter.originalPlanId;
42
- }
43
-
44
- return query;
45
- };
46
-
47
- /**
48
- * Generic function to find plans with flexible filtering
49
- */
50
- export const findPlans = async (
51
- filter?: PlanFilter,
52
- options?: PlanQueryOptions,
53
- ): Promise<PlanDoc[]> => {
54
- let query: Filter<Plan> = {};
55
-
56
- if (filter) {
57
- // Build the base query from simple filter properties
58
- const simpleFilter: SimplePlanFilter = {
59
- _id: filter._id,
60
- productKey: filter.productKey,
61
- isActive: filter.isActive,
62
- currency: filter.currency,
63
- region: filter.region,
64
- countryCode: filter.countryCode,
65
- originalPlanId: filter.originalPlanId,
66
- };
67
-
68
- // Apply simple filters if any are present
69
- const baseQuery = buildSimpleQuery(simpleFilter);
70
- if (Object.keys(baseQuery).length > 0) {
71
- query = baseQuery;
72
- }
73
-
74
- // Add OR conditions if present
75
- if (filter.or && filter.or.length > 0) {
76
- query.$or = filter.or.map(buildSimpleQuery);
77
- }
78
-
79
- // Add AND conditions if present
80
- if (filter.and && filter.and.length > 0) {
81
- query.$and = filter.and.map(buildSimpleQuery);
82
- }
83
- }
84
-
85
- const cursor = getPlansCollection().find(query);
86
- return await applyQueryOptions(cursor, options).toArray();
87
- };
88
-
89
- export const findPlansByQuery = async (
90
- query: Filter<Plan>,
91
- options?: PlanQueryOptions,
92
- ): Promise<PlanDoc[]> => {
93
- const cursor = getPlansCollection().find(query);
94
- return await applyQueryOptions(cursor, options).toArray();
95
- };
96
-
97
- export const countPlans = async (query: Filter<Plan>): Promise<number> => {
98
- return getPlansCollection().countDocuments(query);
99
- };
100
-
101
- export const createPlanDoc = async (
102
- planData: Omit<Plan, "createdAt" | "updatedAt">,
103
- ): Promise<PlanDoc> => {
104
- const now = new Date();
105
- const result = await getPlansCollection().insertOne({
106
- ...planData,
107
- createdAt: now,
108
- updatedAt: now,
109
- });
110
-
111
- const plans = await findPlans({ _id: result.insertedId });
112
- if (!plans[0]) throw new Error("Failed to retrieve created plan");
113
- return plans[0];
114
- };
115
-
116
- export const updatePlanDoc = async (
117
- planId: ObjectId,
118
- updates: Partial<Omit<Plan, "createdAt" | "updatedAt">>,
119
- ): Promise<PlanDoc | null> => {
120
- return await getPlansCollection().findOneAndUpdate(
121
- { _id: planId },
122
- {
123
- $set: {
124
- ...updates,
125
- updatedAt: new Date(),
126
- },
127
- },
128
- {
129
- returnDocument: "after",
130
- },
131
- );
132
- };
1
+ import {
2
+ getDb,
3
+ Plan,
4
+ PlanDoc,
5
+ PlanFilter,
6
+ PlanQueryOptions,
7
+ SimplePlanFilter,
8
+ } from "../index";
9
+ import { Filter, ObjectId } from "mongodb";
10
+ import { applyQueryOptions } from "../utils/query.utils";
11
+
12
+ export const getPlansCollection = () => {
13
+ return getDb().collection<Plan>("plans");
14
+ };
15
+
16
+ /**
17
+ * Converts a simple filter to MongoDB query format
18
+ */
19
+ const buildSimpleQuery = (filter: SimplePlanFilter): Filter<Plan> => {
20
+ const query: Filter<Plan> = {};
21
+
22
+ if (filter._id) {
23
+ query._id = new ObjectId(filter._id);
24
+ }
25
+ if (filter.productKey !== undefined) {
26
+ query.productKey = filter.productKey;
27
+ }
28
+ if (filter.isActive !== undefined) {
29
+ query.isActive = filter.isActive;
30
+ }
31
+ if (filter.currency !== undefined) {
32
+ query.currency = filter.currency;
33
+ }
34
+ if (filter.region !== undefined) {
35
+ query.region = filter.region;
36
+ }
37
+ if (filter.countryCode !== undefined) {
38
+ query.countryCode = filter.countryCode;
39
+ }
40
+ if (filter.originalPlanId !== undefined) {
41
+ query.originalPlanId = filter.originalPlanId;
42
+ }
43
+
44
+ return query;
45
+ };
46
+
47
+ /**
48
+ * Generic function to find plans with flexible filtering
49
+ */
50
+ export const findPlans = async (
51
+ filter?: PlanFilter,
52
+ options?: PlanQueryOptions,
53
+ ): Promise<PlanDoc[]> => {
54
+ let query: Filter<Plan> = {};
55
+
56
+ if (filter) {
57
+ // Build the base query from simple filter properties
58
+ const simpleFilter: SimplePlanFilter = {
59
+ _id: filter._id,
60
+ productKey: filter.productKey,
61
+ isActive: filter.isActive,
62
+ currency: filter.currency,
63
+ region: filter.region,
64
+ countryCode: filter.countryCode,
65
+ originalPlanId: filter.originalPlanId,
66
+ };
67
+
68
+ // Apply simple filters if any are present
69
+ const baseQuery = buildSimpleQuery(simpleFilter);
70
+ if (Object.keys(baseQuery).length > 0) {
71
+ query = baseQuery;
72
+ }
73
+
74
+ // Add OR conditions if present
75
+ if (filter.or && filter.or.length > 0) {
76
+ query.$or = filter.or.map(buildSimpleQuery);
77
+ }
78
+
79
+ // Add AND conditions if present
80
+ if (filter.and && filter.and.length > 0) {
81
+ query.$and = filter.and.map(buildSimpleQuery);
82
+ }
83
+ }
84
+
85
+ const cursor = getPlansCollection().find(query);
86
+ return await applyQueryOptions(cursor, options).toArray();
87
+ };
88
+
89
+ export const findPlansByQuery = async (
90
+ query: Filter<Plan>,
91
+ options?: PlanQueryOptions,
92
+ ): Promise<PlanDoc[]> => {
93
+ const cursor = getPlansCollection().find(query);
94
+ return await applyQueryOptions(cursor, options).toArray();
95
+ };
96
+
97
+ export const countPlans = async (query: Filter<Plan>): Promise<number> => {
98
+ return getPlansCollection().countDocuments(query);
99
+ };
100
+
101
+ export const createPlanDoc = async (
102
+ planData: Omit<Plan, "createdAt" | "updatedAt">,
103
+ ): Promise<PlanDoc> => {
104
+ const now = new Date();
105
+ const result = await getPlansCollection().insertOne({
106
+ ...planData,
107
+ createdAt: now,
108
+ updatedAt: now,
109
+ });
110
+
111
+ const plans = await findPlans({ _id: result.insertedId });
112
+ if (!plans[0]) throw new Error("Failed to retrieve created plan");
113
+ return plans[0];
114
+ };
115
+
116
+ export const updatePlanDoc = async (
117
+ planId: ObjectId,
118
+ updates: Partial<Omit<Plan, "createdAt" | "updatedAt">>,
119
+ ): Promise<PlanDoc | null> => {
120
+ return await getPlansCollection().findOneAndUpdate(
121
+ { _id: planId },
122
+ {
123
+ $set: {
124
+ ...updates,
125
+ updatedAt: new Date(),
126
+ },
127
+ },
128
+ {
129
+ returnDocument: "after",
130
+ },
131
+ );
132
+ };
@@ -1,89 +1,89 @@
1
- import { Sort, ObjectId, WithId } from "mongodb";
2
-
3
- export const CURRENCY_CODES = ["ILS", "USD", "EUR"] as const;
4
- export type CurrencyCode = (typeof CURRENCY_CODES)[number];
5
-
6
- /** Required fields for creating a new plan */
7
- export const PLAN_REQUIRED_FIELDS = [
8
- "productKey",
9
- "name",
10
- "monthlyCallQuota",
11
- "currency",
12
- "priceMonthlyMinor",
13
- "isActive",
14
- ];
15
-
16
- /** All allowed fields that can be set/updated on a plan (excluding system fields) */
17
- export const PLAN_ALLOWED_FIELDS = [
18
- "productKey",
19
- "name",
20
- "monthlyCallQuota",
21
- "currency",
22
- "priceMonthlyMinor",
23
- "region",
24
- "countryCode",
25
- "isActive",
26
- "originalPlanId",
27
- "tax",
28
- "metadata",
29
- "updatedAt",
30
- ];
31
-
32
- /** Logical product family, like "basic-500". Multiple regional variants can share it. */
33
- export type ProductKey =
34
- | "basic-500"
35
- | "pro-1100"
36
- | "scale-6000"
37
- | (string & {});
38
-
39
- /** Optional targeting to keep variants explicit */
40
- export type RegionCode = "IL" | "EU" | "US" | (string & {});
41
- export type CountryCode = "IL" | "DE" | "FR" | "ES" | "GB" | (string & {});
42
-
43
- export type Tax = {
44
- vatIncluded: boolean;
45
- vatRatePct: number;
46
- countryCode?: CountryCode;
47
- };
48
-
49
- export type Plan = {
50
- productKey: ProductKey;
51
- name: string;
52
- monthlyCallQuota: number;
53
- currency: CurrencyCode;
54
- priceMonthlyMinor: number;
55
- region?: RegionCode;
56
- countryCode?: CountryCode;
57
- isActive: boolean;
58
- isFree?: boolean;
59
- createdAt: Date;
60
- updatedAt: Date;
61
- originalPlanId?: string;
62
- tax?: Tax;
63
- metadata?: Record<string, unknown>;
64
- };
65
-
66
- export type SimplePlanFilter = {
67
- _id?: ObjectId | string;
68
- productKey?: ProductKey;
69
- isActive?: boolean;
70
- currency?: CurrencyCode;
71
- region?: RegionCode;
72
- countryCode?: CountryCode;
73
- originalPlanId?: string;
74
- };
75
-
76
- export type PlanFilter = SimplePlanFilter & {
77
- or?: SimplePlanFilter[];
78
- and?: SimplePlanFilter[];
79
- };
80
-
81
- export type PlanQueryOptions = {
82
- sort?: Sort;
83
- skip?: number;
84
- limit?: number;
85
- };
86
-
87
- // Convenient aliases
88
- export type PlanDoc = WithId<Plan>;
89
- export type Plans = PlanDoc[];
1
+ import { Sort, ObjectId, WithId } from "mongodb";
2
+
3
+ export const CURRENCY_CODES = ["ILS", "USD", "EUR"] as const;
4
+ export type CurrencyCode = (typeof CURRENCY_CODES)[number];
5
+
6
+ /** Required fields for creating a new plan */
7
+ export const PLAN_REQUIRED_FIELDS = [
8
+ "productKey",
9
+ "name",
10
+ "monthlyCallQuota",
11
+ "currency",
12
+ "priceMonthlyMinor",
13
+ "isActive",
14
+ ];
15
+
16
+ /** All allowed fields that can be set/updated on a plan (excluding system fields) */
17
+ export const PLAN_ALLOWED_FIELDS = [
18
+ "productKey",
19
+ "name",
20
+ "monthlyCallQuota",
21
+ "currency",
22
+ "priceMonthlyMinor",
23
+ "region",
24
+ "countryCode",
25
+ "isActive",
26
+ "originalPlanId",
27
+ "tax",
28
+ "metadata",
29
+ "updatedAt",
30
+ ];
31
+
32
+ /** Logical product family, like "basic-500". Multiple regional variants can share it. */
33
+ export type ProductKey =
34
+ | "basic-500"
35
+ | "pro-1100"
36
+ | "scale-6000"
37
+ | (string & {});
38
+
39
+ /** Optional targeting to keep variants explicit */
40
+ export type RegionCode = "IL" | "EU" | "US" | (string & {});
41
+ export type CountryCode = "IL" | "DE" | "FR" | "ES" | "GB" | (string & {});
42
+
43
+ export type Tax = {
44
+ vatIncluded: boolean;
45
+ vatRatePct: number;
46
+ countryCode?: CountryCode;
47
+ };
48
+
49
+ export type Plan = {
50
+ productKey: ProductKey;
51
+ name: string;
52
+ monthlyCallQuota: number;
53
+ currency: CurrencyCode;
54
+ priceMonthlyMinor: number;
55
+ region?: RegionCode;
56
+ countryCode?: CountryCode;
57
+ isActive: boolean;
58
+ isFree?: boolean;
59
+ createdAt: Date;
60
+ updatedAt: Date;
61
+ originalPlanId?: string;
62
+ tax?: Tax;
63
+ metadata?: Record<string, unknown>;
64
+ };
65
+
66
+ export type SimplePlanFilter = {
67
+ _id?: ObjectId | string;
68
+ productKey?: ProductKey;
69
+ isActive?: boolean;
70
+ currency?: CurrencyCode;
71
+ region?: RegionCode;
72
+ countryCode?: CountryCode;
73
+ originalPlanId?: string;
74
+ };
75
+
76
+ export type PlanFilter = SimplePlanFilter & {
77
+ or?: SimplePlanFilter[];
78
+ and?: SimplePlanFilter[];
79
+ };
80
+
81
+ export type PlanQueryOptions = {
82
+ sort?: Sort;
83
+ skip?: number;
84
+ limit?: number;
85
+ };
86
+
87
+ // Convenient aliases
88
+ export type PlanDoc = WithId<Plan>;
89
+ export type Plans = PlanDoc[];
@@ -1,7 +1,7 @@
1
- export {
2
- getResultsCollection,
3
- initializeResultDocument,
4
- findResultById,
5
- findResultByCallSid,
6
- } from "./results.getter";
7
- export type * from "./results.types";
1
+ export {
2
+ getResultsCollection,
3
+ initializeResultDocument,
4
+ findResultById,
5
+ findResultByCallSid,
6
+ } from "./results.getter";
7
+ export type * from "./results.types";
@@ -1,35 +1,39 @@
1
- import { Collection, ObjectId } from "mongodb";
2
- import { getDb, Session } from "../index";
3
- import type { Result } from "./results.types";
4
-
5
- export const getResultsCollection = (): Collection<Result> =>
6
- getDb().collection<Result>("results");
7
-
8
- export const createRunId = (): string => {
9
- return `run_${new ObjectId().toString()}`;
10
- };
11
-
12
- export const initializeResultDocument = async (
13
- clientId: string,
14
- session?: Session,
15
- ): Promise<Result> => {
16
- const { insertedId } = await getResultsCollection().insertOne({
17
- runId: createRunId(),
18
- date: new Date(),
19
- calls: [],
20
- sessionId: session ? session._id!.toString() : "incomingCall",
21
- sessionName: session ? session.session_name : "incomingCall",
22
- clientId,
23
- });
24
- const result = await getResultsCollection().findOne({ _id: insertedId });
25
- if (!result) throw new Error("Failed to initialized result");
26
- return result;
27
- };
28
-
29
- export const findResultById = async (resultId: string | ObjectId): Promise<Result | null> => {
30
- return getResultsCollection().findOne({ _id: new ObjectId(resultId) });
31
- };
32
-
33
- export const findResultByCallSid = async (callSid: string): Promise<Result | null> => {
34
- return getResultsCollection().findOne({ "calls.callSid": callSid });
35
- };
1
+ import { Collection, ObjectId } from "mongodb";
2
+ import { getDb, Session } from "../index";
3
+ import type { Result } from "./results.types";
4
+
5
+ export const getResultsCollection = (): Collection<Result> =>
6
+ getDb().collection<Result>("results");
7
+
8
+ export const createRunId = (): string => {
9
+ return `run_${new ObjectId().toString()}`;
10
+ };
11
+
12
+ export const initializeResultDocument = async (
13
+ clientId: string,
14
+ session?: Session,
15
+ ): Promise<Result> => {
16
+ const { insertedId } = await getResultsCollection().insertOne({
17
+ runId: createRunId(),
18
+ date: new Date(),
19
+ calls: [],
20
+ sessionId: session ? session._id!.toString() : "incomingCall",
21
+ sessionName: session ? session.session_name : "incomingCall",
22
+ clientId,
23
+ });
24
+ const result = await getResultsCollection().findOne({ _id: insertedId });
25
+ if (!result) throw new Error("Failed to initialized result");
26
+ return result;
27
+ };
28
+
29
+ export const findResultById = async (
30
+ resultId: string | ObjectId,
31
+ ): Promise<Result | null> => {
32
+ return getResultsCollection().findOne({ _id: new ObjectId(resultId) });
33
+ };
34
+
35
+ export const findResultByCallSid = async (
36
+ callSid: string,
37
+ ): Promise<Result | null> => {
38
+ return getResultsCollection().findOne({ "calls.callSid": callSid });
39
+ };
@@ -1,25 +1,25 @@
1
- export const resultMongoSchema = {
2
- bsonType: "object",
3
- required: [
4
- "_id",
5
- "sessionId",
6
- "status",
7
- "callLength",
8
- "date",
9
- "userAnswer",
10
- "systemSessionId",
11
- "clientId",
12
- ],
13
- properties: {
14
- _id: { bsonType: "objectId" },
15
- sessionId: { bsonType: "string" },
16
- status: { bsonType: "string" },
17
- callLength: { bsonType: "string" },
18
- date: { bsonType: "date" },
19
- userAnswer: { bsonType: "string" },
20
- recordingUrl: { bsonType: ["string", "null"] },
21
- systemSessionId: { bsonType: "string" },
22
- clientId: { bsonType: "string" },
23
- },
24
- additionalProperties: false,
25
- } as const;
1
+ export const resultMongoSchema = {
2
+ bsonType: "object",
3
+ required: [
4
+ "_id",
5
+ "sessionId",
6
+ "status",
7
+ "callLength",
8
+ "date",
9
+ "userAnswer",
10
+ "systemSessionId",
11
+ "clientId",
12
+ ],
13
+ properties: {
14
+ _id: { bsonType: "objectId" },
15
+ sessionId: { bsonType: "string" },
16
+ status: { bsonType: "string" },
17
+ callLength: { bsonType: "string" },
18
+ date: { bsonType: "date" },
19
+ userAnswer: { bsonType: "string" },
20
+ recordingUrl: { bsonType: ["string", "null"] },
21
+ systemSessionId: { bsonType: "string" },
22
+ clientId: { bsonType: "string" },
23
+ },
24
+ additionalProperties: false,
25
+ } as const;
@@ -1,34 +1,34 @@
1
- import { ObjectId } from "mongodb";
2
-
3
- export interface Result {
4
- _id?: ObjectId;
5
- calls: CallResult[];
6
- clientId: string;
7
- date: Date;
8
- runId: string;
9
- sessionId: ObjectId | string;
10
- sessionName: string;
11
- }
12
-
13
- export interface CallResult {
14
- callSid: string;
15
- status: string;
16
- date: Date;
17
- statuses: string[];
18
- userAnswer: string | null;
19
- color: string | null;
20
- name: string | null;
21
- callLength: string;
22
- answeredBy: string | null;
23
- to: string;
24
- from: string;
25
- transcription: TranscriptionSegment[];
26
- flowId: ObjectId | string;
27
- recordingUrl: string | null;
28
- agentHungUp?: boolean;
29
- endReason?: string;
30
- }
31
-
32
- export type TranscriptionSegment =
33
- | { assistant: string; user?: never }
34
- | { user: string; assistant?: never };
1
+ import { ObjectId } from "mongodb";
2
+
3
+ export interface Result {
4
+ _id?: ObjectId;
5
+ calls: CallResult[];
6
+ clientId: string;
7
+ date: Date;
8
+ runId: string;
9
+ sessionId: ObjectId | string;
10
+ sessionName: string;
11
+ }
12
+
13
+ export interface CallResult {
14
+ callSid: string;
15
+ status: string;
16
+ date: Date;
17
+ statuses: string[];
18
+ userAnswer: string | null;
19
+ color: string | null;
20
+ name: string | null;
21
+ callLength: string;
22
+ answeredBy: string | null;
23
+ to: string;
24
+ from: string;
25
+ transcription: TranscriptionSegment[];
26
+ flowId: ObjectId | string;
27
+ recordingUrl: string | null;
28
+ agentHungUp?: boolean;
29
+ endReason?: string;
30
+ }
31
+
32
+ export type TranscriptionSegment =
33
+ | { assistant: string; user?: never }
34
+ | { user: string; assistant?: never };