@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,49 +1,49 @@
|
|
|
1
|
-
import { applyQueryOptions } from "../query.utils";
|
|
2
|
-
|
|
3
|
-
describe("query.utils", () => {
|
|
4
|
-
describe("applyQueryOptions()", () => {
|
|
5
|
-
let mockCursor: any;
|
|
6
|
-
|
|
7
|
-
beforeEach(() => {
|
|
8
|
-
mockCursor = {
|
|
9
|
-
sort: jest.fn().mockReturnThis(),
|
|
10
|
-
skip: jest.fn().mockReturnThis(),
|
|
11
|
-
limit: jest.fn().mockReturnThis(),
|
|
12
|
-
};
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("should return cursor if no options provided", () => {
|
|
16
|
-
const result = applyQueryOptions(mockCursor);
|
|
17
|
-
expect(result).toBe(mockCursor);
|
|
18
|
-
expect(mockCursor.sort).not.toHaveBeenCalled();
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
it("should apply sort, skip, and limit", () => {
|
|
22
|
-
const options = {
|
|
23
|
-
sort: { name: 1 },
|
|
24
|
-
skip: 10,
|
|
25
|
-
limit: 5,
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
const result = applyQueryOptions(mockCursor, options);
|
|
29
|
-
|
|
30
|
-
expect(result).toBe(mockCursor);
|
|
31
|
-
expect(mockCursor.sort).toHaveBeenCalledWith({ name: 1 });
|
|
32
|
-
expect(mockCursor.skip).toHaveBeenCalledWith(10);
|
|
33
|
-
expect(mockCursor.limit).toHaveBeenCalledWith(5);
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
it("should apply only sort if skip and limit are missing", () => {
|
|
37
|
-
const options = {
|
|
38
|
-
sort: { name: 1 },
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
const result = applyQueryOptions(mockCursor, options);
|
|
42
|
-
|
|
43
|
-
expect(result).toBe(mockCursor);
|
|
44
|
-
expect(mockCursor.sort).toHaveBeenCalledWith({ name: 1 });
|
|
45
|
-
expect(mockCursor.skip).not.toHaveBeenCalled();
|
|
46
|
-
expect(mockCursor.limit).not.toHaveBeenCalled();
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
});
|
|
1
|
+
import { applyQueryOptions } from "../query.utils";
|
|
2
|
+
|
|
3
|
+
describe("query.utils", () => {
|
|
4
|
+
describe("applyQueryOptions()", () => {
|
|
5
|
+
let mockCursor: any;
|
|
6
|
+
|
|
7
|
+
beforeEach(() => {
|
|
8
|
+
mockCursor = {
|
|
9
|
+
sort: jest.fn().mockReturnThis(),
|
|
10
|
+
skip: jest.fn().mockReturnThis(),
|
|
11
|
+
limit: jest.fn().mockReturnThis(),
|
|
12
|
+
};
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it("should return cursor if no options provided", () => {
|
|
16
|
+
const result = applyQueryOptions(mockCursor);
|
|
17
|
+
expect(result).toBe(mockCursor);
|
|
18
|
+
expect(mockCursor.sort).not.toHaveBeenCalled();
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
it("should apply sort, skip, and limit", () => {
|
|
22
|
+
const options = {
|
|
23
|
+
sort: { name: 1 },
|
|
24
|
+
skip: 10,
|
|
25
|
+
limit: 5,
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
const result = applyQueryOptions(mockCursor, options);
|
|
29
|
+
|
|
30
|
+
expect(result).toBe(mockCursor);
|
|
31
|
+
expect(mockCursor.sort).toHaveBeenCalledWith({ name: 1 });
|
|
32
|
+
expect(mockCursor.skip).toHaveBeenCalledWith(10);
|
|
33
|
+
expect(mockCursor.limit).toHaveBeenCalledWith(5);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("should apply only sort if skip and limit are missing", () => {
|
|
37
|
+
const options = {
|
|
38
|
+
sort: { name: 1 },
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
const result = applyQueryOptions(mockCursor, options);
|
|
42
|
+
|
|
43
|
+
expect(result).toBe(mockCursor);
|
|
44
|
+
expect(mockCursor.sort).toHaveBeenCalledWith({ name: 1 });
|
|
45
|
+
expect(mockCursor.skip).not.toHaveBeenCalled();
|
|
46
|
+
expect(mockCursor.limit).not.toHaveBeenCalled();
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
});
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { FindCursor } from "mongodb";
|
|
2
|
-
|
|
3
|
-
export type QueryOptions = {
|
|
4
|
-
sort?: any;
|
|
5
|
-
skip?: number;
|
|
6
|
-
limit?: number;
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const applyQueryOptions = <T>(
|
|
10
|
-
cursor: FindCursor<T>,
|
|
11
|
-
options?: QueryOptions,
|
|
12
|
-
): FindCursor<T> => {
|
|
13
|
-
if (!options) return cursor;
|
|
14
|
-
|
|
15
|
-
let result = cursor;
|
|
16
|
-
if (options.sort) result = result.sort(options.sort);
|
|
17
|
-
if (options.skip) result = result.skip(options.skip);
|
|
18
|
-
if (options.limit) result = result.limit(options.limit);
|
|
19
|
-
|
|
20
|
-
return result;
|
|
21
|
-
};
|
|
1
|
+
import { FindCursor } from "mongodb";
|
|
2
|
+
|
|
3
|
+
export type QueryOptions = {
|
|
4
|
+
sort?: any;
|
|
5
|
+
skip?: number;
|
|
6
|
+
limit?: number;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export const applyQueryOptions = <T>(
|
|
10
|
+
cursor: FindCursor<T>,
|
|
11
|
+
options?: QueryOptions,
|
|
12
|
+
): FindCursor<T> => {
|
|
13
|
+
if (!options) return cursor;
|
|
14
|
+
|
|
15
|
+
let result = cursor;
|
|
16
|
+
if (options.sort) result = result.sort(options.sort);
|
|
17
|
+
if (options.skip) result = result.skip(options.skip);
|
|
18
|
+
if (options.limit) result = result.limit(options.limit);
|
|
19
|
+
|
|
20
|
+
return result;
|
|
21
|
+
};
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { MongoMemoryServer } from "mongodb-memory-server";
|
|
2
|
-
import { MongoClient, Db } from "mongodb";
|
|
3
|
-
import { setDb, setMunicipalDataDb } from "../index";
|
|
4
|
-
|
|
5
|
-
let mongoServer: MongoMemoryServer;
|
|
6
|
-
let client: MongoClient;
|
|
7
|
-
|
|
8
|
-
export async function initTestDb(): Promise<Db> {
|
|
9
|
-
mongoServer = await MongoMemoryServer.create({
|
|
10
|
-
instance: { ip: "127.0.0.1" },
|
|
11
|
-
});
|
|
12
|
-
client = new MongoClient(mongoServer.getUri());
|
|
13
|
-
await client.connect();
|
|
14
|
-
const talkpilotDb = client.db();
|
|
15
|
-
const municipalDb = client.db("municipal-data");
|
|
16
|
-
setDb(talkpilotDb);
|
|
17
|
-
setMunicipalDataDb(municipalDb);
|
|
18
|
-
return talkpilotDb;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export async function closeTestDb(): Promise<void> {
|
|
22
|
-
if (client) await client.close();
|
|
23
|
-
if (mongoServer) await mongoServer.stop();
|
|
24
|
-
}
|
|
1
|
+
import { MongoMemoryServer } from "mongodb-memory-server";
|
|
2
|
+
import { MongoClient, Db } from "mongodb";
|
|
3
|
+
import { setDb, setMunicipalDataDb } from "../index";
|
|
4
|
+
|
|
5
|
+
let mongoServer: MongoMemoryServer;
|
|
6
|
+
let client: MongoClient;
|
|
7
|
+
|
|
8
|
+
export async function initTestDb(): Promise<Db> {
|
|
9
|
+
mongoServer = await MongoMemoryServer.create({
|
|
10
|
+
instance: { ip: "127.0.0.1" },
|
|
11
|
+
});
|
|
12
|
+
client = new MongoClient(mongoServer.getUri());
|
|
13
|
+
await client.connect();
|
|
14
|
+
const talkpilotDb = client.db();
|
|
15
|
+
const municipalDb = client.db("municipal-data");
|
|
16
|
+
setDb(talkpilotDb);
|
|
17
|
+
setMunicipalDataDb(municipalDb);
|
|
18
|
+
return talkpilotDb;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export async function closeTestDb(): Promise<void> {
|
|
22
|
+
if (client) await client.close();
|
|
23
|
+
if (mongoServer) await mongoServer.stop();
|
|
24
|
+
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export * from "./talkpilot/agents";
|
|
2
|
-
export * from "./talkpilot/calls";
|
|
3
|
-
export * from "./talkpilot/clientAudioBuffers";
|
|
4
|
-
export * from "./talkpilot/clientsConfig";
|
|
5
|
-
export * from "./talkpilot/flows";
|
|
6
|
-
export * from "./talkpilot/groups";
|
|
7
|
-
export * from "./talkpilot/phone_numbers";
|
|
8
|
-
export * from "./talkpilot/sessions";
|
|
9
|
-
export * from "./municipal/cities";
|
|
10
|
-
export * from "./municipal/departmentsSubjects";
|
|
11
|
-
export * from "./municipal/streets";
|
|
12
|
-
export * from "./municipal/tickets";
|
|
1
|
+
export * from "./talkpilot/agents";
|
|
2
|
+
export * from "./talkpilot/calls";
|
|
3
|
+
export * from "./talkpilot/clientAudioBuffers";
|
|
4
|
+
export * from "./talkpilot/clientsConfig";
|
|
5
|
+
export * from "./talkpilot/flows";
|
|
6
|
+
export * from "./talkpilot/groups";
|
|
7
|
+
export * from "./talkpilot/phone_numbers";
|
|
8
|
+
export * from "./talkpilot/sessions";
|
|
9
|
+
export * from "./municipal/cities";
|
|
10
|
+
export * from "./municipal/departmentsSubjects";
|
|
11
|
+
export * from "./municipal/streets";
|
|
12
|
+
export * from "./municipal/tickets";
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { City } from "../../../municipal";
|
|
5
|
-
|
|
6
|
-
export const cityFactory = Factory.define<City>(() => ({
|
|
7
|
-
_id: new ObjectId(),
|
|
8
|
-
name: faker.location.city().toLowerCase().replace(/\s/g, "_"),
|
|
9
|
-
displayName: faker.location.city(),
|
|
10
|
-
createdAt: new Date(),
|
|
11
|
-
updatedAt: new Date(),
|
|
12
|
-
}));
|
|
13
|
-
|
|
14
|
-
export function createCity(overrides?: Partial<City>): City {
|
|
15
|
-
return cityFactory.build(overrides);
|
|
16
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { City } from "../../../municipal";
|
|
5
|
+
|
|
6
|
+
export const cityFactory = Factory.define<City>(() => ({
|
|
7
|
+
_id: new ObjectId(),
|
|
8
|
+
name: faker.location.city().toLowerCase().replace(/\s/g, "_"),
|
|
9
|
+
displayName: faker.location.city(),
|
|
10
|
+
createdAt: new Date(),
|
|
11
|
+
updatedAt: new Date(),
|
|
12
|
+
}));
|
|
13
|
+
|
|
14
|
+
export function createCity(overrides?: Partial<City>): City {
|
|
15
|
+
return cityFactory.build(overrides);
|
|
16
|
+
}
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { DepartmentSubject } from "../../../municipal";
|
|
5
|
-
import { CityName } from "../../../municipal";
|
|
6
|
-
|
|
7
|
-
const VALID_CITIES: CityName[] = [
|
|
8
|
-
"ashdod",
|
|
9
|
-
"maltar",
|
|
10
|
-
"billit",
|
|
11
|
-
"hashkelon",
|
|
12
|
-
"tests",
|
|
13
|
-
];
|
|
14
|
-
|
|
15
|
-
export const departmentSubjectFactory = Factory.define<DepartmentSubject>(
|
|
16
|
-
() => ({
|
|
17
|
-
_id: new ObjectId(),
|
|
18
|
-
createdAt: new Date(),
|
|
19
|
-
updatedAt: new Date(),
|
|
20
|
-
subjectName: faker.lorem.words(2),
|
|
21
|
-
subject_id: faker.string.numeric(4),
|
|
22
|
-
sub_subject_name: faker.lorem.word(),
|
|
23
|
-
sub_subject_id: faker.string.numeric(4),
|
|
24
|
-
descriptions: [faker.lorem.sentence()],
|
|
25
|
-
cityName: faker.helpers.arrayElement(VALID_CITIES),
|
|
26
|
-
guidelines: null,
|
|
27
|
-
instructions: [],
|
|
28
|
-
communications: [],
|
|
29
|
-
sla: faker.number.int({ min: 24, max: 720 }),
|
|
30
|
-
}),
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
export function createDepartmentSubject(
|
|
34
|
-
overrides?: Partial<DepartmentSubject>,
|
|
35
|
-
): DepartmentSubject {
|
|
36
|
-
return departmentSubjectFactory.build(overrides);
|
|
37
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { DepartmentSubject } from "../../../municipal";
|
|
5
|
+
import { CityName } from "../../../municipal";
|
|
6
|
+
|
|
7
|
+
const VALID_CITIES: CityName[] = [
|
|
8
|
+
"ashdod",
|
|
9
|
+
"maltar",
|
|
10
|
+
"billit",
|
|
11
|
+
"hashkelon",
|
|
12
|
+
"tests",
|
|
13
|
+
];
|
|
14
|
+
|
|
15
|
+
export const departmentSubjectFactory = Factory.define<DepartmentSubject>(
|
|
16
|
+
() => ({
|
|
17
|
+
_id: new ObjectId(),
|
|
18
|
+
createdAt: new Date(),
|
|
19
|
+
updatedAt: new Date(),
|
|
20
|
+
subjectName: faker.lorem.words(2),
|
|
21
|
+
subject_id: faker.string.numeric(4),
|
|
22
|
+
sub_subject_name: faker.lorem.word(),
|
|
23
|
+
sub_subject_id: faker.string.numeric(4),
|
|
24
|
+
descriptions: [faker.lorem.sentence()],
|
|
25
|
+
cityName: faker.helpers.arrayElement(VALID_CITIES),
|
|
26
|
+
guidelines: null,
|
|
27
|
+
instructions: [],
|
|
28
|
+
communications: [],
|
|
29
|
+
sla: faker.number.int({ min: 24, max: 720 }),
|
|
30
|
+
}),
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
export function createDepartmentSubject(
|
|
34
|
+
overrides?: Partial<DepartmentSubject>,
|
|
35
|
+
): DepartmentSubject {
|
|
36
|
+
return departmentSubjectFactory.build(overrides);
|
|
37
|
+
}
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { Street } from "../../../municipal";
|
|
5
|
-
|
|
6
|
-
export const streetFactory = Factory.define<Street>(() => ({
|
|
7
|
-
_id: new ObjectId(),
|
|
8
|
-
createdAt: new Date(),
|
|
9
|
-
updatedAt: new Date(),
|
|
10
|
-
id: faker.string.uuid(),
|
|
11
|
-
name: faker.location.street(),
|
|
12
|
-
cityName: faker.helpers.arrayElement([
|
|
13
|
-
"ashdod",
|
|
14
|
-
"maltar",
|
|
15
|
-
"billit",
|
|
16
|
-
"hashkelon",
|
|
17
|
-
]),
|
|
18
|
-
}));
|
|
19
|
-
|
|
20
|
-
export function createStreet(overrides?: Partial<Street>): Street {
|
|
21
|
-
return streetFactory.build(overrides);
|
|
22
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { Street } from "../../../municipal";
|
|
5
|
+
|
|
6
|
+
export const streetFactory = Factory.define<Street>(() => ({
|
|
7
|
+
_id: new ObjectId(),
|
|
8
|
+
createdAt: new Date(),
|
|
9
|
+
updatedAt: new Date(),
|
|
10
|
+
id: faker.string.uuid(),
|
|
11
|
+
name: faker.location.street(),
|
|
12
|
+
cityName: faker.helpers.arrayElement([
|
|
13
|
+
"ashdod",
|
|
14
|
+
"maltar",
|
|
15
|
+
"billit",
|
|
16
|
+
"hashkelon",
|
|
17
|
+
]),
|
|
18
|
+
}));
|
|
19
|
+
|
|
20
|
+
export function createStreet(overrides?: Partial<Street>): Street {
|
|
21
|
+
return streetFactory.build(overrides);
|
|
22
|
+
}
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { Ticket } from "../../../municipal";
|
|
5
|
-
import { CityName } from "../../../municipal";
|
|
6
|
-
|
|
7
|
-
const VALID_CITIES: CityName[] = [
|
|
8
|
-
"ashdod",
|
|
9
|
-
"maltar",
|
|
10
|
-
"billit",
|
|
11
|
-
"hashkelon",
|
|
12
|
-
"tests",
|
|
13
|
-
];
|
|
14
|
-
|
|
15
|
-
export const ticketFactory = Factory.define<Ticket>(() => ({
|
|
16
|
-
_id: new ObjectId(),
|
|
17
|
-
createdAt: new Date(),
|
|
18
|
-
updatedAt: new Date(),
|
|
19
|
-
cityName: faker.helpers.arrayElement(VALID_CITIES),
|
|
20
|
-
externalCallFields: {
|
|
21
|
-
first_name: faker.person.firstName(),
|
|
22
|
-
last_name: faker.person.lastName(),
|
|
23
|
-
event_description: faker.lorem.sentence(),
|
|
24
|
-
street: faker.location.street(),
|
|
25
|
-
house_number: faker.location.buildingNumber(),
|
|
26
|
-
event_subject_id: faker.string.numeric(4),
|
|
27
|
-
event_sub_subject_id: faker.string.numeric(4),
|
|
28
|
-
image1: faker.image.url(),
|
|
29
|
-
image2: faker.image.url(),
|
|
30
|
-
image3: faker.image.url(),
|
|
31
|
-
file1: faker.system.filePath(),
|
|
32
|
-
file2: faker.system.filePath(),
|
|
33
|
-
file3: faker.system.filePath(),
|
|
34
|
-
},
|
|
35
|
-
}));
|
|
36
|
-
|
|
37
|
-
export function createTicket(overrides?: Partial<Ticket>): Ticket {
|
|
38
|
-
return ticketFactory.build(overrides);
|
|
39
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { Ticket } from "../../../municipal";
|
|
5
|
+
import { CityName } from "../../../municipal";
|
|
6
|
+
|
|
7
|
+
const VALID_CITIES: CityName[] = [
|
|
8
|
+
"ashdod",
|
|
9
|
+
"maltar",
|
|
10
|
+
"billit",
|
|
11
|
+
"hashkelon",
|
|
12
|
+
"tests",
|
|
13
|
+
];
|
|
14
|
+
|
|
15
|
+
export const ticketFactory = Factory.define<Ticket>(() => ({
|
|
16
|
+
_id: new ObjectId(),
|
|
17
|
+
createdAt: new Date(),
|
|
18
|
+
updatedAt: new Date(),
|
|
19
|
+
cityName: faker.helpers.arrayElement(VALID_CITIES),
|
|
20
|
+
externalCallFields: {
|
|
21
|
+
first_name: faker.person.firstName(),
|
|
22
|
+
last_name: faker.person.lastName(),
|
|
23
|
+
event_description: faker.lorem.sentence(),
|
|
24
|
+
street: faker.location.street(),
|
|
25
|
+
house_number: faker.location.buildingNumber(),
|
|
26
|
+
event_subject_id: faker.string.numeric(4),
|
|
27
|
+
event_sub_subject_id: faker.string.numeric(4),
|
|
28
|
+
image1: faker.image.url(),
|
|
29
|
+
image2: faker.image.url(),
|
|
30
|
+
image3: faker.image.url(),
|
|
31
|
+
file1: faker.system.filePath(),
|
|
32
|
+
file2: faker.system.filePath(),
|
|
33
|
+
file3: faker.system.filePath(),
|
|
34
|
+
},
|
|
35
|
+
}));
|
|
36
|
+
|
|
37
|
+
export function createTicket(overrides?: Partial<Ticket>): Ticket {
|
|
38
|
+
return ticketFactory.build(overrides);
|
|
39
|
+
}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { Agent } from "../../../talkpilot";
|
|
5
|
-
|
|
6
|
-
export const agentFactory = Factory.define<Agent>(() => ({
|
|
7
|
-
name: faker.person.fullName(),
|
|
8
|
-
language: "en",
|
|
9
|
-
voice: "alloy",
|
|
10
|
-
instructions: faker.lorem.paragraph(),
|
|
11
|
-
labels: [],
|
|
12
|
-
clientId: new ObjectId().toString(),
|
|
13
|
-
role: "assistant",
|
|
14
|
-
gender: faker.helpers.arrayElement(["male", "female"]),
|
|
15
|
-
}));
|
|
16
|
-
|
|
17
|
-
export function createAgent(overrides?: Partial<Agent>): Agent {
|
|
18
|
-
return agentFactory.build(overrides);
|
|
19
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { Agent } from "../../../talkpilot";
|
|
5
|
+
|
|
6
|
+
export const agentFactory = Factory.define<Agent>(() => ({
|
|
7
|
+
name: faker.person.fullName(),
|
|
8
|
+
language: "en",
|
|
9
|
+
voice: "alloy",
|
|
10
|
+
instructions: faker.lorem.paragraph(),
|
|
11
|
+
labels: [],
|
|
12
|
+
clientId: new ObjectId().toString(),
|
|
13
|
+
role: "assistant",
|
|
14
|
+
gender: faker.helpers.arrayElement(["male", "female"]),
|
|
15
|
+
}));
|
|
16
|
+
|
|
17
|
+
export function createAgent(overrides?: Partial<Agent>): Agent {
|
|
18
|
+
return agentFactory.build(overrides);
|
|
19
|
+
}
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { Call } from "../../../talkpilot";
|
|
5
|
-
|
|
6
|
-
export const callFactory = Factory.define<Call>(() => ({
|
|
7
|
-
callSid: faker.string.uuid(),
|
|
8
|
-
flowId: new ObjectId(),
|
|
9
|
-
clientId: faker.string.uuid(),
|
|
10
|
-
sessionId: null,
|
|
11
|
-
resultId: new ObjectId(),
|
|
12
|
-
customerPhoneNumber: faker.phone.number(),
|
|
13
|
-
agentPhoneNumber: faker.phone.number(),
|
|
14
|
-
isIncomingCall: false,
|
|
15
|
-
isOutgoingCall: true,
|
|
16
|
-
callLength: faker.number.int({ min: 0, max: 3600 }),
|
|
17
|
-
env: "test",
|
|
18
|
-
updatedAt: new Date(),
|
|
19
|
-
createdAt: new Date(),
|
|
20
|
-
}));
|
|
21
|
-
|
|
22
|
-
export function createOutGoingCallDoc(overrides?: Partial<Call>): Call {
|
|
23
|
-
return callFactory.build({
|
|
24
|
-
...overrides,
|
|
25
|
-
isIncomingCall: false,
|
|
26
|
-
isOutgoingCall: true,
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
export function createIncomingCallDoc(overrides?: Partial<Call>): Call {
|
|
31
|
-
return callFactory.build({
|
|
32
|
-
...overrides,
|
|
33
|
-
isIncomingCall: true,
|
|
34
|
-
isOutgoingCall: false,
|
|
35
|
-
sessionId: overrides?.sessionId ?? null,
|
|
36
|
-
});
|
|
37
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { Call } from "../../../talkpilot";
|
|
5
|
+
|
|
6
|
+
export const callFactory = Factory.define<Call>(() => ({
|
|
7
|
+
callSid: faker.string.uuid(),
|
|
8
|
+
flowId: new ObjectId(),
|
|
9
|
+
clientId: faker.string.uuid(),
|
|
10
|
+
sessionId: null,
|
|
11
|
+
resultId: new ObjectId(),
|
|
12
|
+
customerPhoneNumber: faker.phone.number(),
|
|
13
|
+
agentPhoneNumber: faker.phone.number(),
|
|
14
|
+
isIncomingCall: false,
|
|
15
|
+
isOutgoingCall: true,
|
|
16
|
+
callLength: faker.number.int({ min: 0, max: 3600 }),
|
|
17
|
+
env: "test",
|
|
18
|
+
updatedAt: new Date(),
|
|
19
|
+
createdAt: new Date(),
|
|
20
|
+
}));
|
|
21
|
+
|
|
22
|
+
export function createOutGoingCallDoc(overrides?: Partial<Call>): Call {
|
|
23
|
+
return callFactory.build({
|
|
24
|
+
...overrides,
|
|
25
|
+
isIncomingCall: false,
|
|
26
|
+
isOutgoingCall: true,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export function createIncomingCallDoc(overrides?: Partial<Call>): Call {
|
|
31
|
+
return callFactory.build({
|
|
32
|
+
...overrides,
|
|
33
|
+
isIncomingCall: true,
|
|
34
|
+
isOutgoingCall: false,
|
|
35
|
+
sessionId: overrides?.sessionId ?? null,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { faker } from "@faker-js/faker";
|
|
3
|
-
import { CreateAudioBufferInput } from "../../../talkpilot";
|
|
4
|
-
|
|
5
|
-
export const audioBufferInputFactory = Factory.define<CreateAudioBufferInput>(
|
|
6
|
-
() => ({
|
|
7
|
-
callSid: "CA1234567890abcdef1234567890abcdef",
|
|
8
|
-
clientId: faker.string.uuid(),
|
|
9
|
-
bucketStartMs: faker.number.int({ min: 0, max: 1000000 }),
|
|
10
|
-
bucketDurationMs: faker.helpers.arrayElement([500, 1000]),
|
|
11
|
-
data: Buffer.from(faker.string.alphanumeric({ length: 100 })),
|
|
12
|
-
ttlMs: faker.number.int({ min: 1000, max: 3600000 }),
|
|
13
|
-
}),
|
|
14
|
-
);
|
|
15
|
-
|
|
16
|
-
export function createAudioBufferInput(
|
|
17
|
-
overrides?: Partial<CreateAudioBufferInput>,
|
|
18
|
-
): CreateAudioBufferInput {
|
|
19
|
-
return audioBufferInputFactory.build(overrides ?? {});
|
|
20
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { faker } from "@faker-js/faker";
|
|
3
|
+
import { CreateAudioBufferInput } from "../../../talkpilot";
|
|
4
|
+
|
|
5
|
+
export const audioBufferInputFactory = Factory.define<CreateAudioBufferInput>(
|
|
6
|
+
() => ({
|
|
7
|
+
callSid: "CA1234567890abcdef1234567890abcdef",
|
|
8
|
+
clientId: faker.string.uuid(),
|
|
9
|
+
bucketStartMs: faker.number.int({ min: 0, max: 1000000 }),
|
|
10
|
+
bucketDurationMs: faker.helpers.arrayElement([500, 1000]),
|
|
11
|
+
data: Buffer.from(faker.string.alphanumeric({ length: 100 })),
|
|
12
|
+
ttlMs: faker.number.int({ min: 1000, max: 3600000 }),
|
|
13
|
+
}),
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
export function createAudioBufferInput(
|
|
17
|
+
overrides?: Partial<CreateAudioBufferInput>,
|
|
18
|
+
): CreateAudioBufferInput {
|
|
19
|
+
return audioBufferInputFactory.build(overrides ?? {});
|
|
20
|
+
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { Factory } from "fishery";
|
|
2
|
-
import { ObjectId } from "mongodb";
|
|
3
|
-
import { faker } from "@faker-js/faker";
|
|
4
|
-
import type { ClientConfig, ClientConfigDoc } from "../../../talkpilot";
|
|
5
|
-
|
|
6
|
-
export const clientConfigFactory = Factory.define<ClientConfigDoc>(() => ({
|
|
7
|
-
_id: new ObjectId(),
|
|
8
|
-
clientId: faker.string.uuid(),
|
|
9
|
-
products: {},
|
|
10
|
-
}));
|
|
11
|
-
|
|
12
|
-
export function createClientConfig(
|
|
13
|
-
overrides?: Partial<ClientConfig>,
|
|
14
|
-
): ClientConfigDoc {
|
|
15
|
-
return clientConfigFactory.build({
|
|
16
|
-
...overrides,
|
|
17
|
-
});
|
|
18
|
-
}
|
|
1
|
+
import { Factory } from "fishery";
|
|
2
|
+
import { ObjectId } from "mongodb";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import type { ClientConfig, ClientConfigDoc } from "../../../talkpilot";
|
|
5
|
+
|
|
6
|
+
export const clientConfigFactory = Factory.define<ClientConfigDoc>(() => ({
|
|
7
|
+
_id: new ObjectId(),
|
|
8
|
+
clientId: faker.string.uuid(),
|
|
9
|
+
products: {},
|
|
10
|
+
}));
|
|
11
|
+
|
|
12
|
+
export function createClientConfig(
|
|
13
|
+
overrides?: Partial<ClientConfig>,
|
|
14
|
+
): ClientConfigDoc {
|
|
15
|
+
return clientConfigFactory.build({
|
|
16
|
+
...overrides,
|
|
17
|
+
});
|
|
18
|
+
}
|