jp.db.schemas 2.2.9 → 2.2.11
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/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/models/activity-log-user-login.interface.d.ts.map +1 -1
- package/dist/models/activity-log.enum.d.ts.map +1 -1
- package/dist/models/activity-log.enum.js.map +1 -1
- package/dist/models/currency.enum.d.ts.map +1 -1
- package/dist/models/currency.enum.js.map +1 -1
- package/dist/models/rating-add-bulk-item.interface.d.ts.map +1 -1
- package/dist/models/rating-monthly-result.interface.d.ts.map +1 -1
- package/dist/models/tournament-participant.interface.d.ts.map +1 -1
- package/dist/models/tournament-status.enum.d.ts.map +1 -1
- package/dist/models/tournament-status.enum.js.map +1 -1
- package/dist/models/tournament-template.enum.d.ts.map +1 -1
- package/dist/models/tournament-template.enum.js.map +1 -1
- package/dist/models/tournament-winner.interface.d.ts.map +1 -1
- package/dist/models/users-balance-reason.enum.d.ts.map +1 -1
- package/dist/models/users-balance-reason.enum.js.map +1 -1
- package/dist/repositories/achievement.repository.d.ts.map +1 -1
- package/dist/repositories/achievement.repository.js +1 -3
- package/dist/repositories/achievement.repository.js.map +1 -1
- package/dist/repositories/activity-log.repository.d.ts.map +1 -1
- package/dist/repositories/activity-log.repository.js +78 -26
- package/dist/repositories/activity-log.repository.js.map +1 -1
- package/dist/repositories/admin.repository.d.ts.map +1 -1
- package/dist/repositories/admin.repository.js +2 -6
- package/dist/repositories/admin.repository.js.map +1 -1
- package/dist/repositories/article.repository.d.ts.map +1 -1
- package/dist/repositories/article.repository.js +3 -13
- package/dist/repositories/article.repository.js.map +1 -1
- package/dist/repositories/banners.repository.d.ts.map +1 -1
- package/dist/repositories/banners.repository.js +7 -12
- package/dist/repositories/banners.repository.js.map +1 -1
- package/dist/repositories/complains.repository.d.ts.map +1 -1
- package/dist/repositories/complains.repository.js +1 -4
- package/dist/repositories/complains.repository.js.map +1 -1
- package/dist/repositories/daily-bonus.repository.d.ts.map +1 -1
- package/dist/repositories/daily-bonus.repository.js +1 -3
- package/dist/repositories/daily-bonus.repository.js.map +1 -1
- package/dist/repositories/friend.repository.d.ts.map +1 -1
- package/dist/repositories/friend.repository.js.map +1 -1
- package/dist/repositories/game-result.repository.d.ts.map +1 -1
- package/dist/repositories/game-result.repository.js.map +1 -1
- package/dist/repositories/game-statistic.repository.d.ts.map +1 -1
- package/dist/repositories/game-statistic.repository.js.map +1 -1
- package/dist/repositories/index.d.ts +1 -1
- package/dist/repositories/index.d.ts.map +1 -1
- package/dist/repositories/index.js.map +1 -1
- package/dist/repositories/menu.repository.d.ts.map +1 -1
- package/dist/repositories/menu.repository.js.map +1 -1
- package/dist/repositories/notification.repository.d.ts.map +1 -1
- package/dist/repositories/notification.repository.js +6 -9
- package/dist/repositories/notification.repository.js.map +1 -1
- package/dist/repositories/premium.repository.d.ts.map +1 -1
- package/dist/repositories/premium.repository.js +1 -3
- package/dist/repositories/premium.repository.js.map +1 -1
- package/dist/repositories/products.repository.d.ts.map +1 -1
- package/dist/repositories/products.repository.js +1 -3
- package/dist/repositories/products.repository.js.map +1 -1
- package/dist/repositories/purchase.repository.d.ts.map +1 -1
- package/dist/repositories/purchase.repository.js +7 -11
- package/dist/repositories/purchase.repository.js.map +1 -1
- package/dist/repositories/rating.repository.d.ts.map +1 -1
- package/dist/repositories/rating.repository.js +21 -21
- package/dist/repositories/rating.repository.js.map +1 -1
- package/dist/repositories/rooms.repository.d.ts.map +1 -1
- package/dist/repositories/rooms.repository.js +1 -3
- package/dist/repositories/rooms.repository.js.map +1 -1
- package/dist/repositories/rule.repository.d.ts.map +1 -1
- package/dist/repositories/rule.repository.js +1 -3
- package/dist/repositories/rule.repository.js.map +1 -1
- package/dist/repositories/scheduled-tournaments.repository.d.ts.map +1 -1
- package/dist/repositories/scheduled-tournaments.repository.js.map +1 -1
- package/dist/repositories/servers.repository.d.ts.map +1 -1
- package/dist/repositories/servers.repository.js +1 -3
- package/dist/repositories/servers.repository.js.map +1 -1
- package/dist/repositories/setting.repository.d.ts.map +1 -1
- package/dist/repositories/setting.repository.js.map +1 -1
- package/dist/repositories/settings-options.repository.d.ts.map +1 -1
- package/dist/repositories/settings-options.repository.js +1 -3
- package/dist/repositories/settings-options.repository.js.map +1 -1
- package/dist/repositories/simple-rooms.repository.d.ts.map +1 -1
- package/dist/repositories/simple-rooms.repository.js +1 -3
- package/dist/repositories/simple-rooms.repository.js.map +1 -1
- package/dist/repositories/tournament-many-tables-rooms.repository.d.ts.map +1 -1
- package/dist/repositories/tournament-many-tables-rooms.repository.js +23 -18
- package/dist/repositories/tournament-many-tables-rooms.repository.js.map +1 -1
- package/dist/repositories/tournament-one-table-rooms.repository.d.ts.map +1 -1
- package/dist/repositories/tournament-one-table-rooms.repository.js +16 -12
- package/dist/repositories/tournament-one-table-rooms.repository.js.map +1 -1
- package/dist/repositories/users-achievements.repository.d.ts.map +1 -1
- package/dist/repositories/users-achievements.repository.js +2 -6
- package/dist/repositories/users-achievements.repository.js.map +1 -1
- package/dist/repositories/users-balances.repository.d.ts.map +1 -1
- package/dist/repositories/users-balances.repository.js +21 -3
- package/dist/repositories/users-balances.repository.js.map +1 -1
- package/dist/repositories/users.repository.d.ts.map +1 -1
- package/dist/repositories/users.repository.js +28 -34
- package/dist/repositories/users.repository.js.map +1 -1
- package/dist/repositories/welcome.repository.d.ts.map +1 -1
- package/dist/repositories/welcome.repository.js +1 -3
- package/dist/repositories/welcome.repository.js.map +1 -1
- package/dist/schemas/achievement.schema.d.ts.map +1 -1
- package/dist/schemas/achievement.schema.js.map +1 -1
- package/dist/schemas/activity_log.schema.d.ts.map +1 -1
- package/dist/schemas/activity_log.schema.js.map +1 -1
- package/dist/schemas/admin.schema.d.ts.map +1 -1
- package/dist/schemas/admin.schema.js.map +1 -1
- package/dist/schemas/article.schema.d.ts.map +1 -1
- package/dist/schemas/article.schema.js.map +1 -1
- package/dist/schemas/banner.schema.d.ts.map +1 -1
- package/dist/schemas/banner.schema.js.map +1 -1
- package/dist/schemas/channel_message.schema.d.ts.map +1 -1
- package/dist/schemas/channel_message.schema.js.map +1 -1
- package/dist/schemas/complain.schema.d.ts.map +1 -1
- package/dist/schemas/complain.schema.js.map +1 -1
- package/dist/schemas/daily_bonus.schema.d.ts +4 -16
- package/dist/schemas/daily_bonus.schema.d.ts.map +1 -1
- package/dist/schemas/daily_bonus.schema.js +4 -12
- package/dist/schemas/daily_bonus.schema.js.map +1 -1
- package/dist/schemas/feature.schema.d.ts.map +1 -1
- package/dist/schemas/feature.schema.js.map +1 -1
- package/dist/schemas/friend.schema.d.ts.map +1 -1
- package/dist/schemas/friend.schema.js.map +1 -1
- package/dist/schemas/game_result.schema.d.ts +14 -14
- package/dist/schemas/game_result.schema.d.ts.map +1 -1
- package/dist/schemas/game_result.schema.js.map +1 -1
- package/dist/schemas/game_statistic.schema.d.ts.map +1 -1
- package/dist/schemas/game_statistic.schema.js.map +1 -1
- package/dist/schemas/menu.schema.d.ts +2 -12
- package/dist/schemas/menu.schema.d.ts.map +1 -1
- package/dist/schemas/menu.schema.js +2 -6
- package/dist/schemas/menu.schema.js.map +1 -1
- package/dist/schemas/notification.schema.d.ts.map +1 -1
- package/dist/schemas/notification.schema.js.map +1 -1
- package/dist/schemas/premium.schema.d.ts +4 -16
- package/dist/schemas/premium.schema.d.ts.map +1 -1
- package/dist/schemas/premium.schema.js +4 -12
- package/dist/schemas/premium.schema.js.map +1 -1
- package/dist/schemas/product.schema.d.ts +12 -72
- package/dist/schemas/product.schema.d.ts.map +1 -1
- package/dist/schemas/product.schema.js +12 -36
- package/dist/schemas/product.schema.js.map +1 -1
- package/dist/schemas/purchase.schema.d.ts +20 -20
- package/dist/schemas/purchase.schema.d.ts.map +1 -1
- package/dist/schemas/purchase.schema.js.map +1 -1
- package/dist/schemas/purchase_channel.schema.d.ts.map +1 -1
- package/dist/schemas/purchase_channel.schema.js.map +1 -1
- package/dist/schemas/rating.schema.d.ts.map +1 -1
- package/dist/schemas/rating.schema.js.map +1 -1
- package/dist/schemas/rooms.schema.d.ts.map +1 -1
- package/dist/schemas/rooms.schema.js.map +1 -1
- package/dist/schemas/rule.schema.d.ts +4 -16
- package/dist/schemas/rule.schema.d.ts.map +1 -1
- package/dist/schemas/rule.schema.js +4 -12
- package/dist/schemas/rule.schema.js.map +1 -1
- package/dist/schemas/scheduled_tournament.schema.d.ts.map +1 -1
- package/dist/schemas/scheduled_tournament.schema.js.map +1 -1
- package/dist/schemas/server.schema.d.ts.map +1 -1
- package/dist/schemas/server.schema.js.map +1 -1
- package/dist/schemas/setting.schema.d.ts +4 -24
- package/dist/schemas/setting.schema.d.ts.map +1 -1
- package/dist/schemas/setting.schema.js +4 -12
- package/dist/schemas/setting.schema.js.map +1 -1
- package/dist/schemas/settings_option.schema.d.ts +2 -12
- package/dist/schemas/settings_option.schema.d.ts.map +1 -1
- package/dist/schemas/settings_option.schema.js +2 -6
- package/dist/schemas/settings_option.schema.js.map +1 -1
- package/dist/schemas/simple_rooms.schema.d.ts.map +1 -1
- package/dist/schemas/simple_rooms.schema.js.map +1 -1
- package/dist/schemas/tournament_many_tables_rooms.schema.d.ts.map +1 -1
- package/dist/schemas/tournament_many_tables_rooms.schema.js.map +1 -1
- package/dist/schemas/tournament_one_table_rooms.schema.d.ts.map +1 -1
- package/dist/schemas/tournament_one_table_rooms.schema.js.map +1 -1
- package/dist/schemas/user.fb.schema.d.ts.map +1 -1
- package/dist/schemas/user.fb.schema.js.map +1 -1
- package/dist/schemas/user.google.schema.d.ts.map +1 -1
- package/dist/schemas/user.google.schema.js.map +1 -1
- package/dist/schemas/user.ok.schema.d.ts +8 -8
- package/dist/schemas/user.ok.schema.d.ts.map +1 -1
- package/dist/schemas/user.ok.schema.js.map +1 -1
- package/dist/schemas/user.schema.d.ts.map +1 -1
- package/dist/schemas/user.schema.js +1 -1
- package/dist/schemas/user.schema.js.map +1 -1
- package/dist/schemas/user.tg.schema.d.ts.map +1 -1
- package/dist/schemas/user.tg.schema.js.map +1 -1
- package/dist/schemas/user.vk.schema.d.ts.map +1 -1
- package/dist/schemas/user.vk.schema.js.map +1 -1
- package/dist/schemas/user.ya.schema.d.ts.map +1 -1
- package/dist/schemas/user.ya.schema.js.map +1 -1
- package/dist/schemas/users_achievement.schema.d.ts.map +1 -1
- package/dist/schemas/users_achievement.schema.js.map +1 -1
- package/dist/schemas/users_balance.schema.d.ts.map +1 -1
- package/dist/schemas/users_balance.schema.js.map +1 -1
- package/dist/schemas/welcome.schema.d.ts +4 -16
- package/dist/schemas/welcome.schema.d.ts.map +1 -1
- package/dist/schemas/welcome.schema.js +4 -12
- package/dist/schemas/welcome.schema.js.map +1 -1
- package/dist/utils.js.map +1 -1
- package/package.json +11 -4
- package/src/index.ts +218 -188
- package/src/models/account-type.enum.ts +1 -1
- package/src/models/activity-log-user-login.interface.ts +9 -9
- package/src/models/activity-log.enum.ts +7 -7
- package/src/models/currency.enum.ts +5 -5
- package/src/models/rating-add-bulk-item.interface.ts +6 -6
- package/src/models/rating-monthly-result.interface.ts +10 -10
- package/src/models/tournament-participant.interface.ts +3 -3
- package/src/models/tournament-status.enum.ts +4 -4
- package/src/models/tournament-template.enum.ts +1 -1
- package/src/models/tournament-winner.interface.ts +5 -5
- package/src/models/users-balance-reason.enum.ts +7 -7
- package/src/repositories/achievement.repository.ts +7 -8
- package/src/repositories/activity-log.repository.ts +197 -112
- package/src/repositories/admin.repository.ts +7 -10
- package/src/repositories/article.repository.ts +9 -18
- package/src/repositories/banners.repository.ts +25 -25
- package/src/repositories/complains.repository.ts +10 -9
- package/src/repositories/daily-bonus.repository.ts +21 -15
- package/src/repositories/friend.repository.ts +14 -10
- package/src/repositories/game-result.repository.ts +9 -5
- package/src/repositories/game-statistic.repository.ts +14 -10
- package/src/repositories/index.ts +30 -30
- package/src/repositories/menu.repository.ts +8 -10
- package/src/repositories/notification.repository.ts +25 -20
- package/src/repositories/premium.repository.ts +7 -9
- package/src/repositories/products.repository.ts +18 -17
- package/src/repositories/purchase.repository.ts +93 -97
- package/src/repositories/rating.repository.ts +76 -70
- package/src/repositories/rooms.repository.ts +4 -7
- package/src/repositories/rule.repository.ts +5 -9
- package/src/repositories/scheduled-tournaments.repository.ts +12 -7
- package/src/repositories/servers.repository.ts +6 -8
- package/src/repositories/setting.repository.ts +14 -10
- package/src/repositories/settings-options.repository.ts +8 -9
- package/src/repositories/simple-rooms.repository.ts +6 -7
- package/src/repositories/tournament-many-tables-rooms.repository.ts +143 -118
- package/src/repositories/tournament-one-table-rooms.repository.ts +118 -96
- package/src/repositories/users-achievements.repository.ts +35 -32
- package/src/repositories/users-balances.repository.ts +51 -14
- package/src/repositories/users.repository.ts +137 -128
- package/src/repositories/welcome.repository.ts +7 -9
- package/src/schemas/achievement.schema.ts +22 -22
- package/src/schemas/activity_log.schema.ts +20 -20
- package/src/schemas/admin.schema.ts +10 -10
- package/src/schemas/article.schema.ts +20 -20
- package/src/schemas/banner.schema.ts +22 -22
- package/src/schemas/channel_message.schema.ts +18 -17
- package/src/schemas/complain.schema.ts +26 -26
- package/src/schemas/daily_bonus.schema.ts +29 -37
- package/src/schemas/feature.schema.ts +14 -14
- package/src/schemas/friend.schema.ts +29 -31
- package/src/schemas/game_result.schema.ts +41 -41
- package/src/schemas/game_statistic.schema.ts +22 -22
- package/src/schemas/menu.schema.ts +20 -23
- package/src/schemas/notification.schema.ts +36 -36
- package/src/schemas/premium.schema.ts +21 -30
- package/src/schemas/product.schema.ts +69 -87
- package/src/schemas/purchase.schema.ts +37 -37
- package/src/schemas/purchase_channel.schema.ts +18 -17
- package/src/schemas/rating.schema.ts +20 -20
- package/src/schemas/rooms.schema.ts +37 -37
- package/src/schemas/rule.schema.ts +21 -30
- package/src/schemas/scheduled_tournament.schema.ts +58 -57
- package/src/schemas/server.schema.ts +10 -10
- package/src/schemas/setting.schema.ts +28 -34
- package/src/schemas/settings_option.schema.ts +24 -26
- package/src/schemas/simple_rooms.schema.ts +28 -28
- package/src/schemas/tournament_many_tables_rooms.schema.ts +54 -51
- package/src/schemas/tournament_one_table_rooms.schema.ts +52 -49
- package/src/schemas/user.fb.schema.ts +16 -16
- package/src/schemas/user.google.schema.ts +10 -10
- package/src/schemas/user.ok.schema.ts +26 -25
- package/src/schemas/user.schema.ts +127 -125
- package/src/schemas/user.tg.schema.ts +14 -14
- package/src/schemas/user.vk.schema.ts +36 -36
- package/src/schemas/user.ya.schema.ts +10 -10
- package/src/schemas/users_achievement.schema.ts +24 -23
- package/src/schemas/users_balance.schema.ts +18 -18
- package/src/schemas/welcome.schema.ts +21 -30
- package/src/utils.ts +1 -1
|
@@ -6,13 +6,11 @@ import { Server, ServerDocument } from '../';
|
|
|
6
6
|
|
|
7
7
|
@Injectable()
|
|
8
8
|
export class ServersRepository {
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(Server.name) private serverModel: Model<ServerDocument>,
|
|
11
|
+
) {}
|
|
11
12
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
.exec();
|
|
16
|
-
}
|
|
13
|
+
async findServerByName(name: string): Promise<Server | null> {
|
|
14
|
+
return this.serverModel.findOne({ name }).exec();
|
|
15
|
+
}
|
|
17
16
|
}
|
|
18
|
-
|
|
@@ -7,14 +7,18 @@ import { getChannelRegExpFilter } from '../utils';
|
|
|
7
7
|
|
|
8
8
|
@Injectable()
|
|
9
9
|
export class SettingRepository {
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
constructor(
|
|
11
|
+
@InjectModel(Setting.name) private settingModel: Model<SettingDocument>,
|
|
12
|
+
) {}
|
|
12
13
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
14
|
+
async findSettings(
|
|
15
|
+
channel: string,
|
|
16
|
+
game: string,
|
|
17
|
+
): Promise<Array<Setting> | null> {
|
|
18
|
+
return this.settingModel
|
|
19
|
+
.find({
|
|
20
|
+
channels: getChannelRegExpFilter(channel),
|
|
21
|
+
})
|
|
22
|
+
.exec();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -3,16 +3,15 @@ import { InjectModel } from '@nestjs/mongoose';
|
|
|
3
3
|
import { Model } from 'mongoose';
|
|
4
4
|
|
|
5
5
|
import { SettingsOption, SettingsOptionDocument } from '..';
|
|
6
|
-
import { getChannelRegExpFilter } from '../utils';
|
|
7
6
|
|
|
8
7
|
@Injectable()
|
|
9
8
|
export class SettingsOptionsRepository {
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(SettingsOption.name)
|
|
11
|
+
private settingOptionsModel: Model<SettingsOptionDocument>,
|
|
12
|
+
) {}
|
|
12
13
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
18
|
-
}
|
|
14
|
+
async findSettingsOptions(): Promise<Array<SettingsOption> | null> {
|
|
15
|
+
return this.settingOptionsModel.find().exec();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -6,12 +6,11 @@ import { SimpleRoom, SimpleRoomDocument } from '../';
|
|
|
6
6
|
|
|
7
7
|
@Injectable()
|
|
8
8
|
export class SimpleRoomsRepository {
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(SimpleRoom.name) private roomModel: Model<SimpleRoomDocument>,
|
|
11
|
+
) {}
|
|
11
12
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
.exec();
|
|
16
|
-
}
|
|
13
|
+
async findRooms(gameType: string): Promise<Array<SimpleRoomDocument>> {
|
|
14
|
+
return this.roomModel.find({ gameType }).exec();
|
|
15
|
+
}
|
|
17
16
|
}
|
|
@@ -4,9 +4,9 @@ import { Model } from 'mongoose';
|
|
|
4
4
|
import dayjs from 'dayjs';
|
|
5
5
|
|
|
6
6
|
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
7
|
+
TournamentManyTablesRoom,
|
|
8
|
+
TournamentManyTablesRoomDocument,
|
|
9
|
+
TournamentOneTableRoomDocument,
|
|
10
10
|
} from '../';
|
|
11
11
|
import { TournamentStatusEnum } from '../models/tournament-status.enum';
|
|
12
12
|
import { ITournamentWinner } from '../models/tournament-winner.interface';
|
|
@@ -15,132 +15,157 @@ import { ITournamentParticipant } from '../models/tournament-participant.interfa
|
|
|
15
15
|
|
|
16
16
|
@Injectable()
|
|
17
17
|
export class TournamentManyTablesRoomsRepository {
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
constructor(
|
|
19
|
+
@InjectModel(TournamentManyTablesRoom.name)
|
|
20
|
+
private tournamentModel: Model<TournamentManyTablesRoomDocument>,
|
|
21
|
+
) {}
|
|
20
22
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
async findTournamentById(
|
|
24
|
+
tournamentId: string,
|
|
25
|
+
): Promise<TournamentManyTablesRoomDocument | null> {
|
|
26
|
+
return this.tournamentModel.findById(tournamentId).exec();
|
|
27
|
+
}
|
|
26
28
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
29
|
+
async findTemplateById(
|
|
30
|
+
templateId: string,
|
|
31
|
+
gameType: string,
|
|
32
|
+
): Promise<TournamentOneTableRoomDocument | null> {
|
|
33
|
+
return this.tournamentModel.findOne({ templateId, gameType }).exec();
|
|
34
|
+
}
|
|
32
35
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
36
|
+
async findActualTournaments(
|
|
37
|
+
gameType: string,
|
|
38
|
+
): Promise<Array<TournamentManyTablesRoomDocument>> {
|
|
39
|
+
return this.tournamentModel
|
|
40
|
+
.find({
|
|
41
|
+
$and: [
|
|
42
|
+
{
|
|
43
|
+
isTemplate: false,
|
|
44
|
+
gameType,
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
$or: [
|
|
48
|
+
{ status: TournamentStatusEnum.STATE_WAITING_FOR_START },
|
|
49
|
+
{ finishDate: { $gte: dayjs().subtract(1, 'day').toDate() } },
|
|
50
|
+
],
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
})
|
|
54
|
+
.exec();
|
|
55
|
+
}
|
|
51
56
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
57
|
+
async findWaitingTournamentByDate(
|
|
58
|
+
gameType: string,
|
|
59
|
+
startDate: Date,
|
|
60
|
+
endDate: Date,
|
|
61
|
+
): Promise<TournamentOneTableRoomDocument | null> {
|
|
62
|
+
return this.tournamentModel
|
|
63
|
+
.findOne({
|
|
64
|
+
gameType,
|
|
65
|
+
status: TournamentStatusEnum.STATE_WAITING_FOR_START,
|
|
66
|
+
isTemplate: false,
|
|
67
|
+
scheduleDate: { $gte: startDate, $lt: endDate },
|
|
68
|
+
})
|
|
69
|
+
.exec();
|
|
70
|
+
}
|
|
62
71
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
72
|
+
async createTournament(
|
|
73
|
+
tournament: Partial<TournamentManyTablesRoom>,
|
|
74
|
+
): Promise<TournamentManyTablesRoomDocument> {
|
|
75
|
+
return this.tournamentModel.create(tournament);
|
|
76
|
+
}
|
|
66
77
|
|
|
67
|
-
|
|
68
|
-
|
|
78
|
+
async scheduleTournamentFromMasterTemplate(
|
|
79
|
+
gameType: string,
|
|
80
|
+
scheduleDate: Date,
|
|
81
|
+
): Promise<TournamentManyTablesRoomDocument> {
|
|
82
|
+
const masterTemplate = await this.findTemplateById(
|
|
83
|
+
TournamentTemplateEnum.MASTER,
|
|
84
|
+
gameType,
|
|
85
|
+
);
|
|
69
86
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
87
|
+
return this.createTournament({
|
|
88
|
+
title: masterTemplate.title,
|
|
89
|
+
subtitle: masterTemplate.subtitle,
|
|
90
|
+
description: masterTemplate.description,
|
|
91
|
+
tableSize: masterTemplate.tableSize,
|
|
92
|
+
bet: masterTemplate.bet,
|
|
93
|
+
ticketPrice: masterTemplate.ticketPrice,
|
|
94
|
+
roomType: masterTemplate.roomType,
|
|
95
|
+
gameType: masterTemplate.gameType,
|
|
96
|
+
rulesType: masterTemplate.rulesType,
|
|
97
|
+
deckType: masterTemplate.deckType,
|
|
98
|
+
maxParticipants: masterTemplate.maxParticipants,
|
|
99
|
+
participants: masterTemplate.participants,
|
|
100
|
+
status: masterTemplate.status,
|
|
101
|
+
winners: masterTemplate.winners,
|
|
102
|
+
createDate: new Date(),
|
|
103
|
+
isTemplate: false,
|
|
104
|
+
templateId: undefined,
|
|
105
|
+
scheduleDate,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
91
108
|
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
109
|
+
async updateTournament(
|
|
110
|
+
tournamentId: string,
|
|
111
|
+
tournament: Partial<TournamentManyTablesRoom>,
|
|
112
|
+
): Promise<TournamentManyTablesRoomDocument> {
|
|
113
|
+
return this.tournamentModel
|
|
114
|
+
.findByIdAndUpdate(tournamentId, {
|
|
115
|
+
$set: {
|
|
116
|
+
...tournament,
|
|
117
|
+
},
|
|
118
|
+
})
|
|
119
|
+
.exec();
|
|
120
|
+
}
|
|
101
121
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
122
|
+
async removeTournament(tournamentId: string): Promise<void> {
|
|
123
|
+
await this.tournamentModel.findByIdAndDelete(tournamentId);
|
|
124
|
+
}
|
|
105
125
|
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
126
|
+
async startTournament(tournamentId: string): Promise<void> {
|
|
127
|
+
await this.tournamentModel
|
|
128
|
+
.findByIdAndUpdate(tournamentId, {
|
|
129
|
+
$set: {
|
|
130
|
+
startDate: new Date(),
|
|
131
|
+
status: TournamentStatusEnum.STATE_IN_PROGRESS,
|
|
132
|
+
},
|
|
133
|
+
})
|
|
134
|
+
.exec();
|
|
135
|
+
}
|
|
116
136
|
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
137
|
+
async cancelTournament(tournamentId: string): Promise<void> {
|
|
138
|
+
await this.tournamentModel
|
|
139
|
+
.findByIdAndUpdate(tournamentId, {
|
|
140
|
+
$set: {
|
|
141
|
+
finishDate: new Date(),
|
|
142
|
+
status: TournamentStatusEnum.STATE_CANCELLED,
|
|
143
|
+
},
|
|
144
|
+
})
|
|
145
|
+
.exec();
|
|
146
|
+
}
|
|
127
147
|
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
148
|
+
async finishTournament(
|
|
149
|
+
tournamentId: string,
|
|
150
|
+
winners: Array<ITournamentWinner>,
|
|
151
|
+
): Promise<void> {
|
|
152
|
+
await this.tournamentModel
|
|
153
|
+
.findByIdAndUpdate(tournamentId, {
|
|
154
|
+
$set: {
|
|
155
|
+
finishDate: new Date(),
|
|
156
|
+
status: TournamentStatusEnum.STATE_FINISHED,
|
|
157
|
+
winners,
|
|
158
|
+
},
|
|
159
|
+
})
|
|
160
|
+
.exec();
|
|
161
|
+
}
|
|
139
162
|
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
163
|
+
async addPlayerToParticipants(
|
|
164
|
+
tournamentId: string,
|
|
165
|
+
player: ITournamentParticipant,
|
|
166
|
+
): Promise<void> {
|
|
167
|
+
await this.tournamentModel
|
|
168
|
+
.findByIdAndUpdate(tournamentId, { $push: { participants: player } })
|
|
169
|
+
.exec();
|
|
170
|
+
}
|
|
146
171
|
}
|
|
@@ -11,110 +11,132 @@ import { TournamentTemplateEnum } from '../models/tournament-template.enum';
|
|
|
11
11
|
|
|
12
12
|
@Injectable()
|
|
13
13
|
export class TournamentOneTableRoomsRepository {
|
|
14
|
-
|
|
15
|
-
|
|
14
|
+
constructor(
|
|
15
|
+
@InjectModel(TournamentOneTableRoom.name)
|
|
16
|
+
private tournamentModel: Model<TournamentOneTableRoomDocument>,
|
|
17
|
+
) {}
|
|
16
18
|
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
async findTournamentById(
|
|
20
|
+
tournamentId: string,
|
|
21
|
+
): Promise<TournamentOneTableRoomDocument | null> {
|
|
22
|
+
return this.tournamentModel.findById(tournamentId).exec();
|
|
23
|
+
}
|
|
22
24
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
async findTemplateById(
|
|
26
|
+
templateId: string,
|
|
27
|
+
gameType: string,
|
|
28
|
+
): Promise<TournamentOneTableRoomDocument | null> {
|
|
29
|
+
return this.tournamentModel
|
|
30
|
+
.findOne({ isTemplate: true, templateId, gameType })
|
|
31
|
+
.exec();
|
|
32
|
+
}
|
|
28
33
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
34
|
+
async findActualTournaments(
|
|
35
|
+
gameType: string,
|
|
36
|
+
): Promise<Array<TournamentOneTableRoomDocument>> {
|
|
37
|
+
return this.tournamentModel
|
|
38
|
+
.find({
|
|
39
|
+
$and: [
|
|
40
|
+
{
|
|
41
|
+
isTemplate: false,
|
|
42
|
+
gameType,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
$or: [
|
|
46
|
+
{ status: TournamentStatusEnum.STATE_WAITING_FOR_START },
|
|
47
|
+
{ finishDate: { $gte: dayjs().subtract(1, 'hour').toDate() } },
|
|
48
|
+
],
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
})
|
|
52
|
+
.exec();
|
|
53
|
+
}
|
|
47
54
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
55
|
+
async findWaitingTournament(
|
|
56
|
+
gameType: string,
|
|
57
|
+
): Promise<TournamentOneTableRoomDocument | null> {
|
|
58
|
+
return this.tournamentModel
|
|
59
|
+
.findOne({
|
|
60
|
+
gameType,
|
|
61
|
+
status: TournamentStatusEnum.STATE_WAITING_FOR_START,
|
|
62
|
+
isTemplate: false,
|
|
63
|
+
})
|
|
64
|
+
.exec();
|
|
65
|
+
}
|
|
57
66
|
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
67
|
+
async createTournament(
|
|
68
|
+
tournament: Partial<TournamentOneTableRoom>,
|
|
69
|
+
): Promise<TournamentOneTableRoomDocument> {
|
|
70
|
+
return this.tournamentModel.create(tournament);
|
|
71
|
+
}
|
|
61
72
|
|
|
62
|
-
|
|
63
|
-
|
|
73
|
+
async createTournamentFromMasterTemplate(
|
|
74
|
+
gameType: string,
|
|
75
|
+
): Promise<TournamentOneTableRoomDocument> {
|
|
76
|
+
const masterTemplate = await this.findTemplateById(
|
|
77
|
+
TournamentTemplateEnum.MASTER,
|
|
78
|
+
gameType,
|
|
79
|
+
);
|
|
64
80
|
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
81
|
+
return this.createTournament({
|
|
82
|
+
title: masterTemplate.title,
|
|
83
|
+
subtitle: masterTemplate.subtitle,
|
|
84
|
+
description: masterTemplate.description,
|
|
85
|
+
tableSize: masterTemplate.tableSize,
|
|
86
|
+
bet: masterTemplate.bet,
|
|
87
|
+
ticketPrice: masterTemplate.ticketPrice,
|
|
88
|
+
roomType: masterTemplate.roomType,
|
|
89
|
+
gameType: masterTemplate.gameType,
|
|
90
|
+
rulesType: masterTemplate.rulesType,
|
|
91
|
+
deckType: masterTemplate.deckType,
|
|
92
|
+
maxParticipants: masterTemplate.maxParticipants,
|
|
93
|
+
participants: masterTemplate.participants,
|
|
94
|
+
status: masterTemplate.status,
|
|
95
|
+
winners: masterTemplate.winners,
|
|
96
|
+
createDate: new Date(),
|
|
97
|
+
isTemplate: false,
|
|
98
|
+
templateId: undefined,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
85
101
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
102
|
+
async startTournament(
|
|
103
|
+
tournamentId: string,
|
|
104
|
+
participants: Array<ITournamentParticipant>,
|
|
105
|
+
): Promise<void> {
|
|
106
|
+
await this.tournamentModel
|
|
107
|
+
.findByIdAndUpdate(tournamentId, {
|
|
108
|
+
$set: {
|
|
109
|
+
startDate: new Date(),
|
|
110
|
+
status: TournamentStatusEnum.STATE_IN_PROGRESS,
|
|
111
|
+
participants,
|
|
112
|
+
},
|
|
113
|
+
})
|
|
114
|
+
.exec();
|
|
115
|
+
}
|
|
97
116
|
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
117
|
+
async cancelTournament(tournamentId: string): Promise<void> {
|
|
118
|
+
await this.tournamentModel
|
|
119
|
+
.findByIdAndUpdate(tournamentId, {
|
|
120
|
+
$set: {
|
|
121
|
+
finishDate: new Date(),
|
|
122
|
+
status: TournamentStatusEnum.STATE_CANCELLED,
|
|
123
|
+
},
|
|
124
|
+
})
|
|
125
|
+
.exec();
|
|
126
|
+
}
|
|
108
127
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
128
|
+
async finishTournament(
|
|
129
|
+
tournamentId: string,
|
|
130
|
+
winners: Array<ITournamentWinner>,
|
|
131
|
+
): Promise<void> {
|
|
132
|
+
await this.tournamentModel
|
|
133
|
+
.findByIdAndUpdate(tournamentId, {
|
|
134
|
+
$set: {
|
|
135
|
+
finishDate: new Date(),
|
|
136
|
+
status: TournamentStatusEnum.STATE_FINISHED,
|
|
137
|
+
winners,
|
|
138
|
+
},
|
|
139
|
+
})
|
|
140
|
+
.exec();
|
|
141
|
+
}
|
|
120
142
|
}
|