@trafficgroup/knex-rel 0.1.11 → 0.1.12
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/.claude/settings.local.json +2 -5
- package/CLAUDE.md +11 -2
- package/dist/constants/folder.constants.d.ts +12 -0
- package/dist/constants/folder.constants.js +28 -0
- package/dist/constants/folder.constants.js.map +1 -0
- package/dist/constants/video.constants.d.ts +2 -2
- package/dist/constants/video.constants.js +9 -5
- package/dist/constants/video.constants.js.map +1 -1
- package/dist/dao/VideoMinuteResultDAO.d.ts +1 -1
- package/dist/dao/VideoMinuteResultDAO.js +29 -23
- package/dist/dao/VideoMinuteResultDAO.js.map +1 -1
- package/dist/dao/auth/auth.dao.js +4 -1
- package/dist/dao/auth/auth.dao.js.map +1 -1
- package/dist/dao/batch/batch.dao.js +13 -14
- package/dist/dao/batch/batch.dao.js.map +1 -1
- package/dist/dao/camera/camera.dao.js +10 -7
- package/dist/dao/camera/camera.dao.js.map +1 -1
- package/dist/dao/chat/chat.dao.d.ts +1 -1
- package/dist/dao/chat/chat.dao.js +27 -40
- package/dist/dao/chat/chat.dao.js.map +1 -1
- package/dist/dao/folder/folder.dao.d.ts +10 -1
- package/dist/dao/folder/folder.dao.js +44 -6
- package/dist/dao/folder/folder.dao.js.map +1 -1
- package/dist/dao/location/location.dao.js +16 -9
- package/dist/dao/location/location.dao.js.map +1 -1
- package/dist/dao/message/message.dao.d.ts +1 -1
- package/dist/dao/message/message.dao.js +18 -26
- package/dist/dao/message/message.dao.js.map +1 -1
- package/dist/dao/report-configuration/report-configuration.dao.js +32 -31
- package/dist/dao/report-configuration/report-configuration.dao.js.map +1 -1
- package/dist/dao/study/study.dao.js +7 -2
- package/dist/dao/study/study.dao.js.map +1 -1
- package/dist/dao/user/user.dao.js +4 -1
- package/dist/dao/user/user.dao.js.map +1 -1
- package/dist/dao/user-push-notification-token/user-push-notification-token.dao.js +26 -8
- package/dist/dao/user-push-notification-token/user-push-notification-token.dao.js.map +1 -1
- package/dist/dao/video/video.dao.js +30 -28
- package/dist/dao/video/video.dao.js.map +1 -1
- package/dist/index.d.ts +8 -5
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/interfaces/batch/batch.interfaces.d.ts +1 -1
- package/dist/interfaces/camera/camera.interfaces.d.ts +1 -1
- package/dist/interfaces/chat/chat.interfaces.d.ts +3 -3
- package/dist/interfaces/folder/folder.interfaces.d.ts +1 -1
- package/dist/interfaces/message/message.interfaces.d.ts +2 -2
- package/dist/interfaces/study/study.interfaces.d.ts +2 -2
- package/dist/interfaces/user/user.interfaces.d.ts +1 -1
- package/dist/interfaces/user-push-notification-token/user-push-notification-token.interfaces.d.ts +1 -1
- package/dist/interfaces/video/video.interfaces.d.ts +2 -2
- package/migrations/20250717160737_migration.ts +1 -1
- package/migrations/20250717160908_migration.ts +5 -2
- package/migrations/20250717161310_migration.ts +1 -1
- package/migrations/20250717161406_migration.ts +3 -3
- package/migrations/20250717162431_migration.ts +1 -1
- package/migrations/20250717173228_migration.ts +2 -2
- package/migrations/20250717204731_migration.ts +1 -1
- package/migrations/20250722210109_migration.ts +8 -4
- package/migrations/20250722211019_migration.ts +1 -1
- package/migrations/20250723153852_migration.ts +13 -10
- package/migrations/20250723162257_migration.ts +4 -7
- package/migrations/20250723171109_migration.ts +4 -7
- package/migrations/20250723205331_migration.ts +6 -9
- package/migrations/20250724191345_migration.ts +8 -11
- package/migrations/20250730180932_migration.ts +14 -13
- package/migrations/20250730213625_migration.ts +8 -11
- package/migrations/20250804124509_migration.ts +26 -21
- package/migrations/20250804132053_migration.ts +5 -8
- package/migrations/20250804164518_migration.ts +7 -7
- package/migrations/20250823223016_migration.ts +32 -21
- package/migrations/20250910015452_migration.ts +18 -6
- package/migrations/20250911000000_migration.ts +18 -4
- package/migrations/20250917144153_migration.ts +14 -7
- package/migrations/20250930200521_migration.ts +8 -4
- package/migrations/20251010143500_migration.ts +27 -6
- package/migrations/20251020225758_migration.ts +51 -15
- package/migrations/20251112120000_migration.ts +10 -2
- package/migrations/20251112120200_migration.ts +19 -7
- package/migrations/20251112120300_migration.ts +7 -2
- package/package.json +1 -1
- package/src/constants/folder.constants.ts +29 -0
- package/src/constants/video.constants.ts +11 -7
- package/src/d.types.ts +18 -14
- package/src/dao/VideoMinuteResultDAO.ts +72 -49
- package/src/dao/auth/auth.dao.ts +58 -55
- package/src/dao/batch/batch.dao.ts +101 -98
- package/src/dao/camera/camera.dao.ts +124 -121
- package/src/dao/chat/chat.dao.ts +45 -45
- package/src/dao/folder/folder.dao.ts +112 -55
- package/src/dao/location/location.dao.ts +109 -87
- package/src/dao/message/message.dao.ts +32 -32
- package/src/dao/report-configuration/report-configuration.dao.ts +370 -342
- package/src/dao/study/study.dao.ts +88 -63
- package/src/dao/user/user.dao.ts +52 -50
- package/src/dao/user-push-notification-token/user-push-notification-token.dao.ts +80 -48
- package/src/dao/video/video.dao.ts +385 -334
- package/src/entities/BaseEntity.ts +1 -1
- package/src/index.ts +42 -17
- package/src/interfaces/auth/auth.interfaces.ts +10 -10
- package/src/interfaces/batch/batch.interfaces.ts +1 -1
- package/src/interfaces/camera/camera.interfaces.ts +9 -9
- package/src/interfaces/chat/chat.interfaces.ts +4 -4
- package/src/interfaces/folder/folder.interfaces.ts +2 -2
- package/src/interfaces/location/location.interfaces.ts +7 -7
- package/src/interfaces/message/message.interfaces.ts +3 -3
- package/src/interfaces/report-configuration/report-configuration.interfaces.ts +16 -16
- package/src/interfaces/study/study.interfaces.ts +3 -3
- package/src/interfaces/user/user.interfaces.ts +9 -9
- package/src/interfaces/user-push-notification-token/user-push-notification-token.interfaces.ts +9 -9
- package/src/interfaces/video/video.interfaces.ts +34 -34
|
@@ -20,25 +20,19 @@ class ChatDAO {
|
|
|
20
20
|
}
|
|
21
21
|
create(item) {
|
|
22
22
|
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const [result] = yield this._knex(
|
|
24
|
-
.insert(item)
|
|
25
|
-
.returning('*');
|
|
23
|
+
const [result] = yield this._knex("chat").insert(item).returning("*");
|
|
26
24
|
return result;
|
|
27
25
|
});
|
|
28
26
|
}
|
|
29
27
|
getById(id) {
|
|
30
28
|
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
-
const result = yield this._knex(
|
|
32
|
-
.where('id', id)
|
|
33
|
-
.first();
|
|
29
|
+
const result = yield this._knex("chat").where("id", id).first();
|
|
34
30
|
return result || null;
|
|
35
31
|
});
|
|
36
32
|
}
|
|
37
33
|
getByUuid(uuid) {
|
|
38
34
|
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
-
const result = yield this._knex(
|
|
40
|
-
.where('uuid', uuid)
|
|
41
|
-
.first();
|
|
35
|
+
const result = yield this._knex("chat").where("uuid", uuid).first();
|
|
42
36
|
return result || null;
|
|
43
37
|
});
|
|
44
38
|
}
|
|
@@ -46,11 +40,11 @@ class ChatDAO {
|
|
|
46
40
|
return __awaiter(this, arguments, void 0, function* (page = 1, limit = 10) {
|
|
47
41
|
const offset = (page - 1) * limit;
|
|
48
42
|
const [results, [{ count }]] = yield Promise.all([
|
|
49
|
-
this._knex(
|
|
50
|
-
.orderBy(
|
|
43
|
+
this._knex("chat")
|
|
44
|
+
.orderBy("created_at", "desc")
|
|
51
45
|
.limit(limit)
|
|
52
46
|
.offset(offset),
|
|
53
|
-
this._knex(
|
|
47
|
+
this._knex("chat").count("* as count"),
|
|
54
48
|
]);
|
|
55
49
|
const totalCount = parseInt(count);
|
|
56
50
|
return {
|
|
@@ -60,24 +54,22 @@ class ChatDAO {
|
|
|
60
54
|
limit,
|
|
61
55
|
count: results.length,
|
|
62
56
|
totalCount,
|
|
63
|
-
totalPages: Math.ceil(totalCount / limit)
|
|
57
|
+
totalPages: Math.ceil(totalCount / limit),
|
|
64
58
|
};
|
|
65
59
|
});
|
|
66
60
|
}
|
|
67
61
|
update(id, item) {
|
|
68
62
|
return __awaiter(this, void 0, void 0, function* () {
|
|
69
|
-
const [result] = yield this._knex(
|
|
70
|
-
.where(
|
|
63
|
+
const [result] = yield this._knex("chat")
|
|
64
|
+
.where("id", id)
|
|
71
65
|
.update(Object.assign(Object.assign({}, item), { updated_at: new Date() }))
|
|
72
|
-
.returning(
|
|
66
|
+
.returning("*");
|
|
73
67
|
return result || null;
|
|
74
68
|
});
|
|
75
69
|
}
|
|
76
70
|
delete(id) {
|
|
77
71
|
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
-
const result = yield this._knex(
|
|
79
|
-
.where('id', id)
|
|
80
|
-
.delete();
|
|
72
|
+
const result = yield this._knex("chat").where("id", id).delete();
|
|
81
73
|
return result > 0;
|
|
82
74
|
});
|
|
83
75
|
}
|
|
@@ -85,14 +77,12 @@ class ChatDAO {
|
|
|
85
77
|
return __awaiter(this, arguments, void 0, function* (userId, page = 1, limit = 10) {
|
|
86
78
|
const offset = (page - 1) * limit;
|
|
87
79
|
const [results, [{ count }]] = yield Promise.all([
|
|
88
|
-
this._knex(
|
|
89
|
-
.where(
|
|
90
|
-
.orderBy(
|
|
80
|
+
this._knex("chat")
|
|
81
|
+
.where("userId", userId)
|
|
82
|
+
.orderBy("created_at", "desc")
|
|
91
83
|
.limit(limit)
|
|
92
84
|
.offset(offset),
|
|
93
|
-
this._knex(
|
|
94
|
-
.where('userId', userId)
|
|
95
|
-
.count('* as count')
|
|
85
|
+
this._knex("chat").where("userId", userId).count("* as count"),
|
|
96
86
|
]);
|
|
97
87
|
const totalCount = parseInt(count);
|
|
98
88
|
return {
|
|
@@ -102,7 +92,7 @@ class ChatDAO {
|
|
|
102
92
|
limit,
|
|
103
93
|
count: results.length,
|
|
104
94
|
totalCount,
|
|
105
|
-
totalPages: Math.ceil(totalCount / limit)
|
|
95
|
+
totalPages: Math.ceil(totalCount / limit),
|
|
106
96
|
};
|
|
107
97
|
});
|
|
108
98
|
}
|
|
@@ -110,25 +100,22 @@ class ChatDAO {
|
|
|
110
100
|
return __awaiter(this, arguments, void 0, function* (userId, page = 1, limit = 10, query) {
|
|
111
101
|
const offset = (page - 1) * limit;
|
|
112
102
|
// Build data query
|
|
113
|
-
let dataQuery = this._knex(
|
|
114
|
-
.where(
|
|
115
|
-
.where(
|
|
103
|
+
let dataQuery = this._knex("chat")
|
|
104
|
+
.where("userId", userId)
|
|
105
|
+
.where("status", "active");
|
|
116
106
|
// Build count query
|
|
117
|
-
let countQuery = this._knex(
|
|
118
|
-
.where(
|
|
119
|
-
.where(
|
|
107
|
+
let countQuery = this._knex("chat")
|
|
108
|
+
.where("userId", userId)
|
|
109
|
+
.where("status", "active");
|
|
120
110
|
// Apply search filter if query is provided
|
|
121
111
|
if (query && query.trim()) {
|
|
122
112
|
const searchTerm = `%${query.trim()}%`;
|
|
123
|
-
dataQuery = dataQuery.where(
|
|
124
|
-
countQuery = countQuery.where(
|
|
113
|
+
dataQuery = dataQuery.where("title", "ILIKE", searchTerm);
|
|
114
|
+
countQuery = countQuery.where("title", "ILIKE", searchTerm);
|
|
125
115
|
}
|
|
126
116
|
const [results, [{ count }]] = yield Promise.all([
|
|
127
|
-
dataQuery
|
|
128
|
-
|
|
129
|
-
.limit(limit)
|
|
130
|
-
.offset(offset),
|
|
131
|
-
countQuery.count('* as count')
|
|
117
|
+
dataQuery.orderBy("created_at", "desc").limit(limit).offset(offset),
|
|
118
|
+
countQuery.count("* as count"),
|
|
132
119
|
]);
|
|
133
120
|
const totalCount = parseInt(count);
|
|
134
121
|
const totalPages = Math.ceil(totalCount / limit);
|
|
@@ -141,7 +128,7 @@ class ChatDAO {
|
|
|
141
128
|
count: results.length,
|
|
142
129
|
totalCount,
|
|
143
130
|
totalPages,
|
|
144
|
-
hasMore
|
|
131
|
+
hasMore,
|
|
145
132
|
};
|
|
146
133
|
});
|
|
147
134
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat.dao.js","sourceRoot":"","sources":["../../../src/dao/chat/chat.dao.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"chat.dao.js","sourceRoot":"","sources":["../../../src/dao/chat/chat.dao.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
import { IBaseDAO, IDataPaginator } from "../../d.types";
|
|
2
2
|
import { IFolder } from "../../interfaces/folder/folder.interfaces";
|
|
3
|
+
import { FolderSortField, FolderStatus } from "../../constants/folder.constants";
|
|
4
|
+
import { SortOrder } from "../../constants/video.constants";
|
|
5
|
+
export interface IFolderFilters {
|
|
6
|
+
studyId?: number | null;
|
|
7
|
+
status?: FolderStatus;
|
|
8
|
+
search?: string;
|
|
9
|
+
sortBy?: FolderSortField;
|
|
10
|
+
sortOrder?: SortOrder;
|
|
11
|
+
}
|
|
3
12
|
export declare class FolderDAO implements IBaseDAO<IFolder> {
|
|
4
13
|
private _knex;
|
|
5
14
|
create(item: IFolder): Promise<IFolder>;
|
|
@@ -7,5 +16,5 @@ export declare class FolderDAO implements IBaseDAO<IFolder> {
|
|
|
7
16
|
getByUuid(uuid: string): Promise<IFolder | null>;
|
|
8
17
|
update(id: number, item: Partial<IFolder>): Promise<IFolder | null>;
|
|
9
18
|
delete(id: number): Promise<boolean>;
|
|
10
|
-
getAll(page: number, limit: number,
|
|
19
|
+
getAll(page: number, limit: number, filters?: IFolderFilters): Promise<IDataPaginator<IFolder>>;
|
|
11
20
|
}
|
|
@@ -14,13 +14,16 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.FolderDAO = void 0;
|
|
16
16
|
const KnexConnection_1 = __importDefault(require("../../KnexConnection"));
|
|
17
|
+
const folder_constants_1 = require("../../constants/folder.constants");
|
|
17
18
|
class FolderDAO {
|
|
18
19
|
constructor() {
|
|
19
20
|
this._knex = KnexConnection_1.default.getConnection();
|
|
20
21
|
}
|
|
21
22
|
create(item) {
|
|
22
23
|
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const [createdFolder] = yield this._knex("folders")
|
|
24
|
+
const [createdFolder] = yield this._knex("folders")
|
|
25
|
+
.insert(item)
|
|
26
|
+
.returning("*");
|
|
24
27
|
return createdFolder;
|
|
25
28
|
});
|
|
26
29
|
}
|
|
@@ -46,7 +49,10 @@ class FolderDAO {
|
|
|
46
49
|
}
|
|
47
50
|
update(id, item) {
|
|
48
51
|
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
-
const [updatedFolder] = yield this._knex("folders")
|
|
52
|
+
const [updatedFolder] = yield this._knex("folders")
|
|
53
|
+
.where({ id })
|
|
54
|
+
.update(item)
|
|
55
|
+
.returning("*");
|
|
50
56
|
return updatedFolder || null;
|
|
51
57
|
});
|
|
52
58
|
}
|
|
@@ -56,17 +62,49 @@ class FolderDAO {
|
|
|
56
62
|
return result > 0;
|
|
57
63
|
});
|
|
58
64
|
}
|
|
59
|
-
getAll(page, limit,
|
|
65
|
+
getAll(page, limit, filters) {
|
|
60
66
|
return __awaiter(this, void 0, void 0, function* () {
|
|
61
67
|
const offset = (page - 1) * limit;
|
|
62
68
|
const query = this._knex("folders as f")
|
|
63
69
|
.innerJoin("study as s", "f.studyId", "s.id")
|
|
64
70
|
.leftJoin("locations as l", "s.locationId", "l.id")
|
|
65
71
|
.select("f.*", this._knex.raw("to_jsonb(s.*) as study"), "l.name as locationName", "l.uuid as locationUuid");
|
|
66
|
-
|
|
67
|
-
|
|
72
|
+
// Apply filters
|
|
73
|
+
if (filters) {
|
|
74
|
+
// Filter by studyId
|
|
75
|
+
if (filters.studyId !== undefined && filters.studyId !== null) {
|
|
76
|
+
query.where("f.studyId", filters.studyId);
|
|
77
|
+
}
|
|
78
|
+
// Filter by status
|
|
79
|
+
if (filters.status) {
|
|
80
|
+
query.where("f.status", filters.status);
|
|
81
|
+
}
|
|
82
|
+
// Search by name (case-insensitive)
|
|
83
|
+
if (filters.search) {
|
|
84
|
+
query.whereRaw("LOWER(f.name) LIKE ?", [
|
|
85
|
+
`%${filters.search.toLowerCase()}%`,
|
|
86
|
+
]);
|
|
87
|
+
}
|
|
88
|
+
// Apply sorting
|
|
89
|
+
if (filters.sortBy) {
|
|
90
|
+
const columnName = folder_constants_1.FOLDER_SORT_COLUMN_MAP[filters.sortBy];
|
|
91
|
+
const order = filters.sortOrder || "DESC";
|
|
92
|
+
query.orderBy(columnName, order);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
// Default sort by created_at DESC
|
|
96
|
+
query.orderBy("f.created_at", "DESC");
|
|
97
|
+
}
|
|
68
98
|
}
|
|
69
|
-
|
|
99
|
+
else {
|
|
100
|
+
// Default sort by created_at DESC
|
|
101
|
+
query.orderBy("f.created_at", "DESC");
|
|
102
|
+
}
|
|
103
|
+
const [countResult] = yield query
|
|
104
|
+
.clone()
|
|
105
|
+
.clearSelect()
|
|
106
|
+
.clearOrder()
|
|
107
|
+
.count("* as count");
|
|
70
108
|
const totalCount = +countResult.count;
|
|
71
109
|
const folders = yield query.clone().limit(limit).offset(offset);
|
|
72
110
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"folder.dao.js","sourceRoot":"","sources":["../../../src/dao/folder/folder.dao.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAGA,0EAA+C;
|
|
1
|
+
{"version":3,"file":"folder.dao.js","sourceRoot":"","sources":["../../../src/dao/folder/folder.dao.ts"],"names":[],"mappings":"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"}
|
|
@@ -20,7 +20,9 @@ class LocationDAO {
|
|
|
20
20
|
}
|
|
21
21
|
create(item) {
|
|
22
22
|
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const [createdLocation] = yield this._knex("locations")
|
|
23
|
+
const [createdLocation] = yield this._knex("locations")
|
|
24
|
+
.insert(item)
|
|
25
|
+
.returning("*");
|
|
24
26
|
return createdLocation;
|
|
25
27
|
});
|
|
26
28
|
}
|
|
@@ -38,7 +40,10 @@ class LocationDAO {
|
|
|
38
40
|
}
|
|
39
41
|
update(id, item) {
|
|
40
42
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
const [updatedLocation] = yield this._knex("locations")
|
|
43
|
+
const [updatedLocation] = yield this._knex("locations")
|
|
44
|
+
.where({ id })
|
|
45
|
+
.update(item)
|
|
46
|
+
.returning("*");
|
|
42
47
|
return updatedLocation || null;
|
|
43
48
|
});
|
|
44
49
|
}
|
|
@@ -75,13 +80,11 @@ class LocationDAO {
|
|
|
75
80
|
return __awaiter(this, arguments, void 0, function* (longitude, latitude, radiusKm = 1) {
|
|
76
81
|
// Using ST_DWithin for geographic distance calculation
|
|
77
82
|
// This is a PostgreSQL-specific query for geospatial operations
|
|
78
|
-
const locations = yield this._knex("locations")
|
|
79
|
-
.whereRaw(`ST_DWithin(
|
|
83
|
+
const locations = yield this._knex("locations").whereRaw(`ST_DWithin(
|
|
80
84
|
ST_MakePoint(longitude, latitude)::geography,
|
|
81
85
|
ST_MakePoint(?, ?)::geography,
|
|
82
86
|
?
|
|
83
|
-
)`, [longitude, latitude, radiusKm * 1000]
|
|
84
|
-
);
|
|
87
|
+
)`, [longitude, latitude, radiusKm * 1000]);
|
|
85
88
|
return locations;
|
|
86
89
|
});
|
|
87
90
|
}
|
|
@@ -94,12 +97,16 @@ class LocationDAO {
|
|
|
94
97
|
let query = this._knex("locations");
|
|
95
98
|
// Apply search filter if name provided (escape special chars to prevent pattern injection)
|
|
96
99
|
if (name && name.trim().length > 0) {
|
|
97
|
-
const escapedName = name.trim().replace(/[%_\\]/g,
|
|
98
|
-
query = query.where(
|
|
100
|
+
const escapedName = name.trim().replace(/[%_\\]/g, "\\$&");
|
|
101
|
+
query = query.where("name", "ilike", `%${escapedName}%`);
|
|
99
102
|
}
|
|
100
103
|
const [countResult] = yield query.clone().count("* as count");
|
|
101
104
|
const totalCount = +countResult.count;
|
|
102
|
-
const locations = yield query
|
|
105
|
+
const locations = yield query
|
|
106
|
+
.clone()
|
|
107
|
+
.limit(limit)
|
|
108
|
+
.offset(offset)
|
|
109
|
+
.orderBy("name", "asc");
|
|
103
110
|
return {
|
|
104
111
|
success: true,
|
|
105
112
|
data: locations,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"location.dao.js","sourceRoot":"","sources":["../../../src/dao/location/location.dao.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAIA,0EAA+C;AAE/C,MAAa,WAAW;IAAxB;
|
|
1
|
+
{"version":3,"file":"location.dao.js","sourceRoot":"","sources":["../../../src/dao/location/location.dao.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { IBaseDAO, IDataPaginator } from "../../d.types";
|
|
2
|
-
import { IMessage, IMessageCreate, IMessageUpdate } from
|
|
2
|
+
import { IMessage, IMessageCreate, IMessageUpdate } from "../../interfaces/message/message.interfaces";
|
|
3
3
|
export declare class MessageDAO implements IBaseDAO<IMessage> {
|
|
4
4
|
private _knex;
|
|
5
5
|
create(item: IMessageCreate): Promise<IMessage>;
|
|
@@ -20,17 +20,13 @@ class MessageDAO {
|
|
|
20
20
|
}
|
|
21
21
|
create(item) {
|
|
22
22
|
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
const [result] = yield this._knex(
|
|
24
|
-
.insert(item)
|
|
25
|
-
.returning('*');
|
|
23
|
+
const [result] = yield this._knex("message").insert(item).returning("*");
|
|
26
24
|
return result;
|
|
27
25
|
});
|
|
28
26
|
}
|
|
29
27
|
getById(id) {
|
|
30
28
|
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
-
const result = yield this._knex(
|
|
32
|
-
.where('id', id)
|
|
33
|
-
.first();
|
|
29
|
+
const result = yield this._knex("message").where("id", id).first();
|
|
34
30
|
return result || null;
|
|
35
31
|
});
|
|
36
32
|
}
|
|
@@ -44,11 +40,11 @@ class MessageDAO {
|
|
|
44
40
|
return __awaiter(this, arguments, void 0, function* (page = 1, limit = 10) {
|
|
45
41
|
const offset = (page - 1) * limit;
|
|
46
42
|
const [results, [{ count }]] = yield Promise.all([
|
|
47
|
-
this._knex(
|
|
48
|
-
.orderBy(
|
|
43
|
+
this._knex("message")
|
|
44
|
+
.orderBy("created_at", "asc")
|
|
49
45
|
.limit(limit)
|
|
50
46
|
.offset(offset),
|
|
51
|
-
this._knex(
|
|
47
|
+
this._knex("message").count("* as count"),
|
|
52
48
|
]);
|
|
53
49
|
const totalCount = parseInt(count);
|
|
54
50
|
return {
|
|
@@ -58,24 +54,22 @@ class MessageDAO {
|
|
|
58
54
|
limit,
|
|
59
55
|
count: results.length,
|
|
60
56
|
totalCount,
|
|
61
|
-
totalPages: Math.ceil(totalCount / limit)
|
|
57
|
+
totalPages: Math.ceil(totalCount / limit),
|
|
62
58
|
};
|
|
63
59
|
});
|
|
64
60
|
}
|
|
65
61
|
update(id, item) {
|
|
66
62
|
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
-
const [result] = yield this._knex(
|
|
68
|
-
.where(
|
|
63
|
+
const [result] = yield this._knex("message")
|
|
64
|
+
.where("id", id)
|
|
69
65
|
.update(Object.assign(Object.assign({}, item), { updated_at: new Date() }))
|
|
70
|
-
.returning(
|
|
66
|
+
.returning("*");
|
|
71
67
|
return result || null;
|
|
72
68
|
});
|
|
73
69
|
}
|
|
74
70
|
delete(id) {
|
|
75
71
|
return __awaiter(this, void 0, void 0, function* () {
|
|
76
|
-
const result = yield this._knex(
|
|
77
|
-
.where('id', id)
|
|
78
|
-
.delete();
|
|
72
|
+
const result = yield this._knex("message").where("id", id).delete();
|
|
79
73
|
return result > 0;
|
|
80
74
|
});
|
|
81
75
|
}
|
|
@@ -83,14 +77,12 @@ class MessageDAO {
|
|
|
83
77
|
return __awaiter(this, arguments, void 0, function* (chatId, page = 1, limit = 50) {
|
|
84
78
|
const offset = (page - 1) * limit;
|
|
85
79
|
const [results, [{ count }]] = yield Promise.all([
|
|
86
|
-
this._knex(
|
|
87
|
-
.where(
|
|
88
|
-
.orderBy(
|
|
80
|
+
this._knex("message")
|
|
81
|
+
.where("chatId", chatId)
|
|
82
|
+
.orderBy("created_at", "asc")
|
|
89
83
|
.limit(limit)
|
|
90
84
|
.offset(offset),
|
|
91
|
-
this._knex(
|
|
92
|
-
.where('chatId', chatId)
|
|
93
|
-
.count('* as count')
|
|
85
|
+
this._knex("message").where("chatId", chatId).count("* as count"),
|
|
94
86
|
]);
|
|
95
87
|
const totalCount = parseInt(count);
|
|
96
88
|
return {
|
|
@@ -100,15 +92,15 @@ class MessageDAO {
|
|
|
100
92
|
limit,
|
|
101
93
|
count: results.length,
|
|
102
94
|
totalCount,
|
|
103
|
-
totalPages: Math.ceil(totalCount / limit)
|
|
95
|
+
totalPages: Math.ceil(totalCount / limit),
|
|
104
96
|
};
|
|
105
97
|
});
|
|
106
98
|
}
|
|
107
99
|
getLatestMessages(chatId_1) {
|
|
108
100
|
return __awaiter(this, arguments, void 0, function* (chatId, limit = 50) {
|
|
109
|
-
return yield this._knex(
|
|
110
|
-
.where(
|
|
111
|
-
.orderBy(
|
|
101
|
+
return yield this._knex("message")
|
|
102
|
+
.where("chatId", chatId)
|
|
103
|
+
.orderBy("created_at", "desc")
|
|
112
104
|
.limit(limit)
|
|
113
105
|
.then((messages) => messages.reverse());
|
|
114
106
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"message.dao.js","sourceRoot":"","sources":["../../../src/dao/message/message.dao.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"message.dao.js","sourceRoot":"","sources":["../../../src/dao/message/message.dao.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAOA,0EAA+C;AAE/C,MAAa,UAAU;IAAvB;QACU,UAAK,GAAyB,wBAAW,CAAC,aAAa,EAAE,CAAC;IA2FpE,CAAC;IAzFO,MAAM,CAAC,IAAoB;;YAC/B,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YACzE,OAAO,MAAM,CAAC;QAChB,CAAC;KAAA;IAEK,OAAO,CAAC,EAAU;;YACtB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;YACnE,OAAO,MAAM,IAAI,IAAI,CAAC;QACxB,CAAC;KAAA;IAEK,SAAS,CAAC,IAAY;;YAC1B,yDAAyD;YACzD,OAAO,IAAI,CAAC;QACd,CAAC;KAAA;IAEK,MAAM;6DAAC,IAAI,GAAG,CAAC,EAAE,KAAK,GAAG,EAAE;YAC/B,MAAM,MAAM,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;YAElC,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC/C,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;qBAClB,OAAO,CAAC,YAAY,EAAE,KAAK,CAAC;qBAC5B,KAAK,CAAC,KAAK,CAAC;qBACZ,MAAM,CAAC,MAAM,CAAC;gBACjB,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC;aAC1C,CAAC,CAAC;YAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAe,CAAC,CAAC;YAC7C,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,OAAO;gBACb,IAAI;gBACJ,KAAK;gBACL,KAAK,EAAE,OAAO,CAAC,MAAM;gBACrB,UAAU;gBACV,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;aAC1C,CAAC;QACJ,CAAC;KAAA;IAEK,MAAM,CAAC,EAAU,EAAE,IAAoB;;YAC3C,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;iBACzC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;iBACf,MAAM,iCACF,IAAI,KACP,UAAU,EAAE,IAAI,IAAI,EAAE,IACtB;iBACD,SAAS,CAAC,GAAG,CAAC,CAAC;YAClB,OAAO,MAAM,IAAI,IAAI,CAAC;QACxB,CAAC;KAAA;IAEK,MAAM,CAAC,EAAU;;YACrB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;YACpE,OAAO,MAAM,GAAG,CAAC,CAAC;QACpB,CAAC;KAAA;IAEK,WAAW;6DACf,MAAc,EACd,IAAI,GAAG,CAAC,EACR,KAAK,GAAG,EAAE;YAEV,MAAM,MAAM,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;YAElC,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC/C,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;qBAClB,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;qBACvB,OAAO,CAAC,YAAY,EAAE,KAAK,CAAC;qBAC5B,KAAK,CAAC,KAAK,CAAC;qBACZ,MAAM,CAAC,MAAM,CAAC;gBACjB,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC;aAClE,CAAC,CAAC;YAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAe,CAAC,CAAC;YAC7C,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,OAAO;gBACb,IAAI;gBACJ,KAAK;gBACL,KAAK,EAAE,OAAO,CAAC,MAAM;gBACrB,UAAU;gBACV,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;aAC1C,CAAC;QACJ,CAAC;KAAA;IAEK,iBAAiB;6DAAC,MAAc,EAAE,KAAK,GAAG,EAAE;YAChD,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;iBAC/B,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;iBACvB,OAAO,CAAC,YAAY,EAAE,MAAM,CAAC;iBAC7B,KAAK,CAAC,KAAK,CAAC;iBACZ,IAAI,CAAC,CAAC,QAAoB,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;QACxD,CAAC;KAAA;CACF;AA5FD,gCA4FC"}
|