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
|
@@ -29,33 +29,33 @@ import { UsersBalancesRepository } from './users-balances.repository';
|
|
|
29
29
|
import { UsersAchievementsRepository } from './users-achievements.repository';
|
|
30
30
|
|
|
31
31
|
export {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
32
|
+
AdminRepository,
|
|
33
|
+
ArticleRepository,
|
|
34
|
+
BannersRepository,
|
|
35
|
+
ComplainsRepository,
|
|
36
|
+
NotificationRepository,
|
|
37
|
+
ProductsRepository,
|
|
38
|
+
ScheduledTournamentsRepository,
|
|
39
|
+
ServersRepository,
|
|
40
|
+
UsersRepository,
|
|
41
|
+
MenuRepository,
|
|
42
|
+
RatingRepository,
|
|
43
|
+
GameStatisticRepository,
|
|
44
|
+
RuleRepository,
|
|
45
|
+
FriendRepository,
|
|
46
|
+
SettingRepository,
|
|
47
|
+
PremiumRepository,
|
|
48
|
+
WelcomeRepository,
|
|
49
|
+
DailyBonusRepository,
|
|
50
|
+
RoomsRepository,
|
|
51
|
+
GameResultRepository,
|
|
52
|
+
SimpleRoomsRepository,
|
|
53
|
+
TournamentOneTableRoomsRepository,
|
|
54
|
+
TournamentManyTablesRoomsRepository,
|
|
55
|
+
ActivityLogRepository,
|
|
56
|
+
AchievementRepository,
|
|
57
|
+
PurchaseRepository,
|
|
58
|
+
SettingsOptionsRepository,
|
|
59
|
+
UsersBalancesRepository,
|
|
60
|
+
UsersAchievementsRepository,
|
|
61
|
+
};
|
|
@@ -7,15 +7,13 @@ import { getChannelRegExpFilter } from '../utils';
|
|
|
7
7
|
|
|
8
8
|
@Injectable()
|
|
9
9
|
export class MenuRepository {
|
|
10
|
-
|
|
11
|
-
}
|
|
10
|
+
constructor(@InjectModel(Menu.name) private menuModel: Model<MenuDocument>) {}
|
|
12
11
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
12
|
+
async findMenus(channel: string, game: string): Promise<Array<Menu> | null> {
|
|
13
|
+
return this.menuModel
|
|
14
|
+
.find({
|
|
15
|
+
channels: getChannelRegExpFilter(channel),
|
|
16
|
+
})
|
|
17
|
+
.exec();
|
|
18
|
+
}
|
|
20
19
|
}
|
|
21
|
-
|
|
@@ -6,18 +6,21 @@ import { Notification, NotificationDocument } from '../';
|
|
|
6
6
|
|
|
7
7
|
@Injectable()
|
|
8
8
|
export class NotificationRepository {
|
|
9
|
-
constructor
|
|
10
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(Notification.name)
|
|
11
|
+
private notificationModel: Model<NotificationDocument>,
|
|
12
|
+
) {}
|
|
11
13
|
|
|
12
|
-
async findById
|
|
13
|
-
return this.notificationModel
|
|
14
|
-
.findById(id)
|
|
15
|
-
.exec();
|
|
14
|
+
async findById(id: string): Promise<Notification | null> {
|
|
15
|
+
return this.notificationModel.findById(id).exec();
|
|
16
16
|
}
|
|
17
17
|
|
|
18
|
-
async findAndCount
|
|
19
|
-
|
|
20
|
-
|
|
18
|
+
async findAndCount(
|
|
19
|
+
limit: number,
|
|
20
|
+
skip: number,
|
|
21
|
+
): Promise<{
|
|
22
|
+
items: Array<Notification>;
|
|
23
|
+
total: number;
|
|
21
24
|
}> {
|
|
22
25
|
const items = await this.notificationModel
|
|
23
26
|
.find()
|
|
@@ -26,29 +29,31 @@ export class NotificationRepository {
|
|
|
26
29
|
.skip(skip)
|
|
27
30
|
.exec();
|
|
28
31
|
|
|
29
|
-
const total = await this.notificationModel
|
|
30
|
-
.find()
|
|
31
|
-
.countDocuments()
|
|
32
|
-
.exec();
|
|
32
|
+
const total = await this.notificationModel.find().countDocuments().exec();
|
|
33
33
|
|
|
34
34
|
return { items, total };
|
|
35
35
|
}
|
|
36
36
|
|
|
37
|
-
public async crateNotification
|
|
37
|
+
public async crateNotification(
|
|
38
|
+
notification: Notification,
|
|
39
|
+
): Promise<Notification> {
|
|
38
40
|
return this.notificationModel.create(notification);
|
|
39
41
|
}
|
|
40
42
|
|
|
41
|
-
async updateNotification
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
43
|
+
async updateNotification(
|
|
44
|
+
notificationId: string,
|
|
45
|
+
notification: Partial<Notification>,
|
|
46
|
+
): Promise<void> {
|
|
47
|
+
await this.notificationModel
|
|
48
|
+
.findByIdAndUpdate(notificationId, {
|
|
45
49
|
$set: {
|
|
46
50
|
...notification,
|
|
47
51
|
},
|
|
48
|
-
})
|
|
52
|
+
})
|
|
53
|
+
.exec();
|
|
49
54
|
}
|
|
50
55
|
|
|
51
|
-
public async removeNotification
|
|
56
|
+
public async removeNotification(notificationId: string): Promise<void> {
|
|
52
57
|
await this.notificationModel.findByIdAndDelete(notificationId);
|
|
53
58
|
}
|
|
54
59
|
}
|
|
@@ -3,16 +3,14 @@ import { InjectModel } from '@nestjs/mongoose';
|
|
|
3
3
|
import { Model } from 'mongoose';
|
|
4
4
|
|
|
5
5
|
import { Premium, PremiumDocument } from '..';
|
|
6
|
-
import { getChannelRegExpFilter } from '../utils';
|
|
7
6
|
|
|
8
7
|
@Injectable()
|
|
9
8
|
export class PremiumRepository {
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(Premium.name) private premiumModel: Model<PremiumDocument>,
|
|
11
|
+
) {}
|
|
12
12
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
18
|
-
}
|
|
13
|
+
async findPremium(gameType: string): Promise<Premium | null> {
|
|
14
|
+
return this.premiumModel.findOne({ gameType }).exec();
|
|
15
|
+
}
|
|
16
|
+
}
|
|
@@ -7,23 +7,24 @@ import { getChannelRegExpFilter } from '../utils';
|
|
|
7
7
|
|
|
8
8
|
@Injectable()
|
|
9
9
|
export class ProductsRepository {
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
constructor(
|
|
11
|
+
@InjectModel(Product.name) private productModel: Model<ProductDocument>,
|
|
12
|
+
) {}
|
|
12
13
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
.exec();
|
|
17
|
-
}
|
|
14
|
+
async findByProductId(productId: string): Promise<Product | null> {
|
|
15
|
+
return this.productModel.findOne({ productId }).exec();
|
|
16
|
+
}
|
|
18
17
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
18
|
+
async findProducts(
|
|
19
|
+
parentId: string | null,
|
|
20
|
+
channel: string,
|
|
21
|
+
): Promise<Array<Product> | null> {
|
|
22
|
+
return this.productModel
|
|
23
|
+
.find({
|
|
24
|
+
parentId,
|
|
25
|
+
active: true,
|
|
26
|
+
channels: getChannelRegExpFilter(channel),
|
|
27
|
+
})
|
|
28
|
+
.exec();
|
|
29
|
+
}
|
|
28
30
|
}
|
|
29
|
-
|
|
@@ -7,109 +7,105 @@ import { CurrencyEnum } from '../models/currency.enum';
|
|
|
7
7
|
|
|
8
8
|
@Injectable()
|
|
9
9
|
export class PurchaseRepository {
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
constructor(
|
|
11
|
+
@InjectModel(Purchase.name) private purchaseModel: Model<PurchaseDocument>,
|
|
12
|
+
) {}
|
|
12
13
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
.exec();
|
|
17
|
-
}
|
|
14
|
+
async findPurchasesByUserId(userId: string): Promise<Array<Purchase>> {
|
|
15
|
+
return this.purchaseModel.find({ userId }).exec();
|
|
16
|
+
}
|
|
18
17
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
.exec();
|
|
23
|
-
}
|
|
18
|
+
async findPurchaseByVKOrderId(vkOrderId: number): Promise<Purchase | null> {
|
|
19
|
+
return this.purchaseModel.findOne({ vkOrderId }).exec();
|
|
20
|
+
}
|
|
24
21
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
.exec();
|
|
29
|
-
}
|
|
22
|
+
async findPurchaseByYaOrderId(yaOrderId: string): Promise<Purchase | null> {
|
|
23
|
+
return this.purchaseModel.findOne({ yaOrderId }).exec();
|
|
24
|
+
}
|
|
30
25
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
26
|
+
async addVKPurchase(
|
|
27
|
+
userId: string,
|
|
28
|
+
userName: string,
|
|
29
|
+
productId: string,
|
|
30
|
+
productCode: string,
|
|
31
|
+
productName: string,
|
|
32
|
+
price: number,
|
|
33
|
+
vkOrderId: number,
|
|
34
|
+
token: string,
|
|
35
|
+
game: string,
|
|
36
|
+
): Promise<Purchase> {
|
|
37
|
+
return this.addPurchase({
|
|
38
|
+
userId,
|
|
39
|
+
userName,
|
|
40
|
+
productId,
|
|
41
|
+
productCode,
|
|
42
|
+
productName,
|
|
43
|
+
price,
|
|
44
|
+
currency: CurrencyEnum.VK_VOTES,
|
|
45
|
+
vkOrderId,
|
|
46
|
+
token,
|
|
47
|
+
game,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
55
50
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
51
|
+
async addYAPUrchase(
|
|
52
|
+
userId: string,
|
|
53
|
+
userName: string,
|
|
54
|
+
productId: string,
|
|
55
|
+
productCode: string,
|
|
56
|
+
productName: string,
|
|
57
|
+
price: number,
|
|
58
|
+
yaOrderId: string,
|
|
59
|
+
token: string,
|
|
60
|
+
game: string,
|
|
61
|
+
): Promise<Purchase> {
|
|
62
|
+
return this.addPurchase({
|
|
63
|
+
userId,
|
|
64
|
+
userName,
|
|
65
|
+
productId,
|
|
66
|
+
productCode,
|
|
67
|
+
productName,
|
|
68
|
+
price,
|
|
69
|
+
currency: CurrencyEnum.YAN,
|
|
70
|
+
yaOrderId,
|
|
71
|
+
token,
|
|
72
|
+
game,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
80
75
|
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
76
|
+
async addManyTablesTournamentTicketPurchase(
|
|
77
|
+
userId: string,
|
|
78
|
+
userName: string,
|
|
79
|
+
tournamentId: string,
|
|
80
|
+
price: number,
|
|
81
|
+
game: string,
|
|
82
|
+
): Promise<Purchase> {
|
|
83
|
+
return this.addPurchase({
|
|
84
|
+
userId,
|
|
85
|
+
userName,
|
|
86
|
+
productId: '6a192b118e596305dc9d0484',
|
|
87
|
+
productCode: 'tournament_ticket__evening',
|
|
88
|
+
productName: 'Ticket on evenint tournament',
|
|
89
|
+
tournamentId,
|
|
90
|
+
price,
|
|
91
|
+
currency: CurrencyEnum.JP,
|
|
92
|
+
game,
|
|
93
|
+
});
|
|
94
|
+
}
|
|
100
95
|
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
96
|
+
async addPurchase(purchase: Partial<Purchase>): Promise<Purchase> {
|
|
97
|
+
return this.purchaseModel.create(purchase);
|
|
98
|
+
}
|
|
104
99
|
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
100
|
+
async removeByVKOkderId(vkOrderId: number): Promise<Purchase | null> {
|
|
101
|
+
return this.purchaseModel
|
|
102
|
+
.findOneAndUpdate(
|
|
103
|
+
{ vkOrderId },
|
|
104
|
+
{
|
|
105
|
+
removed: true,
|
|
106
|
+
},
|
|
107
|
+
{ new: true },
|
|
108
|
+
)
|
|
109
|
+
.exec();
|
|
110
|
+
}
|
|
114
111
|
}
|
|
115
|
-
|
|
@@ -8,77 +8,83 @@ import { IRatingMonthlyResult } from '../models/rating-monthly-result.interface'
|
|
|
8
8
|
|
|
9
9
|
@Injectable()
|
|
10
10
|
export class RatingRepository {
|
|
11
|
-
|
|
12
|
-
|
|
11
|
+
constructor(
|
|
12
|
+
@InjectModel(Rating.name) private ratingModel: Model<RatingDocument>,
|
|
13
|
+
) {}
|
|
13
14
|
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
15
|
+
async findRating(
|
|
16
|
+
channel: string,
|
|
17
|
+
game: string,
|
|
18
|
+
): Promise<Array<Rating> | null> {
|
|
19
|
+
return this.ratingModel
|
|
20
|
+
.find({
|
|
21
|
+
channels: getChannelRegExpFilter(channel),
|
|
22
|
+
})
|
|
23
|
+
.exec();
|
|
24
|
+
}
|
|
18
25
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
26
|
+
async addBulkPlayerRating(items: Array<Rating>): Promise<void> {
|
|
27
|
+
await this.ratingModel.insertMany(items);
|
|
28
|
+
}
|
|
22
29
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
},
|
|
50
|
-
userId: { $first: "$userId" },
|
|
51
|
-
userName: { $first: "$userName" },
|
|
52
|
-
userAvatarUrl: { $first: "$userAvatarUrl" },
|
|
53
|
-
game: { $first: "$game" },
|
|
54
|
-
channels: { $first: "$channels" },
|
|
55
|
-
count: { $sum: 1 },
|
|
56
|
-
profit: { $sum: "$profit" }
|
|
57
|
-
}
|
|
58
|
-
},
|
|
59
|
-
{
|
|
60
|
-
$sort: { profit: -1 }
|
|
61
|
-
},
|
|
62
|
-
{
|
|
63
|
-
$setWindowFields: {
|
|
64
|
-
sortBy: { profit: -1 },
|
|
65
|
-
output: { rank: { $rank: {} } }
|
|
66
|
-
}
|
|
30
|
+
async getMonthlyRatingList(
|
|
31
|
+
game: string,
|
|
32
|
+
startDate: Date,
|
|
33
|
+
endDate: Date,
|
|
34
|
+
): Promise<Array<IRatingMonthlyResult>> {
|
|
35
|
+
return this.ratingModel.aggregate([
|
|
36
|
+
{
|
|
37
|
+
$match: {
|
|
38
|
+
game,
|
|
39
|
+
date: {
|
|
40
|
+
$gte: startDate,
|
|
41
|
+
$lte: endDate,
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
$group: {
|
|
47
|
+
_id: {
|
|
48
|
+
userId: '$userId',
|
|
49
|
+
date: {
|
|
50
|
+
$dateToString: {
|
|
51
|
+
format: '%Y-%m',
|
|
52
|
+
date: '$date',
|
|
53
|
+
},
|
|
67
54
|
},
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}
|
|
55
|
+
},
|
|
56
|
+
userId: { $first: '$userId' },
|
|
57
|
+
userName: { $first: '$userName' },
|
|
58
|
+
userAvatarUrl: { $first: '$userAvatarUrl' },
|
|
59
|
+
game: { $first: '$game' },
|
|
60
|
+
channels: { $first: '$channels' },
|
|
61
|
+
count: { $sum: 1 },
|
|
62
|
+
profit: { $sum: '$profit' },
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
$sort: { profit: -1 },
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
$setWindowFields: {
|
|
70
|
+
sortBy: { profit: -1 },
|
|
71
|
+
output: { rank: { $rank: {} } },
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
$project: {
|
|
76
|
+
_id: 0,
|
|
77
|
+
id: { $concat: ['$_id.userId', '_', '$_id.date'] },
|
|
78
|
+
userId: 1,
|
|
79
|
+
userName: 1,
|
|
80
|
+
userAvatarUrl: 1,
|
|
81
|
+
game: 1,
|
|
82
|
+
channels: 1,
|
|
83
|
+
count: 1,
|
|
84
|
+
date: '$_id.date',
|
|
85
|
+
rank: 1,
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
]);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
@@ -6,12 +6,9 @@ import { Room, RoomDocument } from '../';
|
|
|
6
6
|
|
|
7
7
|
@Injectable()
|
|
8
8
|
export class RoomsRepository {
|
|
9
|
-
|
|
10
|
-
}
|
|
9
|
+
constructor(@InjectModel(Room.name) private roomModel: Model<RoomDocument>) {}
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
.exec();
|
|
16
|
-
}
|
|
11
|
+
async findRooms(gameType: string): Promise<Array<RoomDocument>> {
|
|
12
|
+
return this.roomModel.find({ gameType }).exec();
|
|
13
|
+
}
|
|
17
14
|
}
|
|
@@ -3,16 +3,12 @@ import { InjectModel } from '@nestjs/mongoose';
|
|
|
3
3
|
import { Model } from 'mongoose';
|
|
4
4
|
|
|
5
5
|
import { Rule, RuleDocument } from '..';
|
|
6
|
-
import { getChannelRegExpFilter } from '../utils';
|
|
7
6
|
|
|
8
7
|
@Injectable()
|
|
9
8
|
export class RuleRepository {
|
|
10
|
-
|
|
11
|
-
}
|
|
9
|
+
constructor(@InjectModel(Rule.name) private ruleModel: Model<RuleDocument>) {}
|
|
12
10
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
18
|
-
}
|
|
11
|
+
async findRule(gameType: string): Promise<Rule | null> {
|
|
12
|
+
return this.ruleModel.findOne({ gameType }).exec();
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -6,22 +6,27 @@ import { ScheduledTournament, ScheduledTournamentDocument } from '../';
|
|
|
6
6
|
|
|
7
7
|
@Injectable()
|
|
8
8
|
export class ScheduledTournamentsRepository {
|
|
9
|
-
constructor
|
|
10
|
-
|
|
9
|
+
constructor(
|
|
10
|
+
@InjectModel(ScheduledTournament.name)
|
|
11
|
+
private scheduledTournamentModel: Model<ScheduledTournamentDocument>,
|
|
12
|
+
) {}
|
|
11
13
|
|
|
12
|
-
async findAndCount
|
|
13
|
-
|
|
14
|
-
|
|
14
|
+
async findAndCount(
|
|
15
|
+
limit: number,
|
|
16
|
+
skip: number,
|
|
17
|
+
): Promise<{
|
|
18
|
+
items: Array<ScheduledTournament>;
|
|
19
|
+
total: number;
|
|
15
20
|
}> {
|
|
16
21
|
const items = await this.scheduledTournamentModel
|
|
17
|
-
.find({ category: 'global'})
|
|
22
|
+
.find({ category: 'global' })
|
|
18
23
|
.sort({ date: -1 })
|
|
19
24
|
.limit(limit)
|
|
20
25
|
.skip(skip)
|
|
21
26
|
.exec();
|
|
22
27
|
|
|
23
28
|
const total = await this.scheduledTournamentModel
|
|
24
|
-
.find({ category: 'global'})
|
|
29
|
+
.find({ category: 'global' })
|
|
25
30
|
.countDocuments()
|
|
26
31
|
.exec();
|
|
27
32
|
|