jp.db.schemas 2.2.10 → 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.
Files changed (83) hide show
  1. package/package.json +37 -37
  2. package/readme.md +3 -3
  3. package/src/index.ts +294 -294
  4. package/src/models/account-type.enum.ts +8 -8
  5. package/src/models/activity-log-user-login.interface.ts +10 -10
  6. package/src/models/activity-log.enum.ts +8 -8
  7. package/src/models/currency.enum.ts +6 -6
  8. package/src/models/rating-add-bulk-item.interface.ts +7 -7
  9. package/src/models/rating-monthly-result.interface.ts +11 -11
  10. package/src/models/tournament-participant.interface.ts +5 -5
  11. package/src/models/tournament-status.enum.ts +6 -6
  12. package/src/models/tournament-template.enum.ts +3 -3
  13. package/src/models/tournament-winner.interface.ts +7 -7
  14. package/src/models/users-balance-reason.enum.ts +8 -8
  15. package/src/repositories/achievement.repository.ts +17 -17
  16. package/src/repositories/activity-log.repository.ts +209 -209
  17. package/src/repositories/admin.repository.ts +20 -20
  18. package/src/repositories/article.repository.ts +24 -24
  19. package/src/repositories/banners.repository.ts +60 -60
  20. package/src/repositories/complains.repository.ts +31 -31
  21. package/src/repositories/daily-bonus.repository.ts +32 -32
  22. package/src/repositories/friend.repository.ts +24 -24
  23. package/src/repositories/game-result.repository.ts +19 -19
  24. package/src/repositories/game-statistic.repository.ts +25 -25
  25. package/src/repositories/index.ts +61 -61
  26. package/src/repositories/menu.repository.ts +19 -19
  27. package/src/repositories/notification.repository.ts +59 -59
  28. package/src/repositories/premium.repository.ts +16 -16
  29. package/src/repositories/products.repository.ts +30 -30
  30. package/src/repositories/purchase.repository.ts +111 -111
  31. package/src/repositories/rating.repository.ts +90 -90
  32. package/src/repositories/rooms.repository.ts +14 -14
  33. package/src/repositories/rule.repository.ts +14 -14
  34. package/src/repositories/scheduled-tournaments.repository.ts +35 -35
  35. package/src/repositories/servers.repository.ts +16 -16
  36. package/src/repositories/setting.repository.ts +24 -24
  37. package/src/repositories/settings-options.repository.ts +17 -17
  38. package/src/repositories/simple-rooms.repository.ts +16 -16
  39. package/src/repositories/tournament-many-tables-rooms.repository.ts +171 -171
  40. package/src/repositories/tournament-one-table-rooms.repository.ts +142 -142
  41. package/src/repositories/users-achievements.repository.ts +46 -46
  42. package/src/repositories/users-balances.repository.ts +65 -65
  43. package/src/repositories/users.repository.ts +153 -153
  44. package/src/repositories/welcome.repository.ts +16 -16
  45. package/src/schemas/achievement.schema.ts +40 -40
  46. package/src/schemas/activity_log.schema.ts +37 -37
  47. package/src/schemas/admin.schema.ts +22 -22
  48. package/src/schemas/article.schema.ts +37 -37
  49. package/src/schemas/banner.schema.ts +40 -40
  50. package/src/schemas/channel_message.schema.ts +32 -32
  51. package/src/schemas/complain.schema.ts +46 -46
  52. package/src/schemas/daily_bonus.schema.ts +49 -49
  53. package/src/schemas/feature.schema.ts +28 -28
  54. package/src/schemas/friend.schema.ts +49 -49
  55. package/src/schemas/game_result.schema.ts +68 -68
  56. package/src/schemas/game_statistic.schema.ts +40 -40
  57. package/src/schemas/menu.schema.ts +37 -37
  58. package/src/schemas/notification.schema.ts +61 -61
  59. package/src/schemas/premium.schema.ts +37 -37
  60. package/src/schemas/product.schema.ts +111 -111
  61. package/src/schemas/purchase.schema.ts +61 -61
  62. package/src/schemas/purchase_channel.schema.ts +32 -32
  63. package/src/schemas/rating.schema.ts +37 -37
  64. package/src/schemas/rooms.schema.ts +63 -63
  65. package/src/schemas/rule.schema.ts +37 -37
  66. package/src/schemas/scheduled_tournament.schema.ts +94 -94
  67. package/src/schemas/server.schema.ts +22 -22
  68. package/src/schemas/setting.schema.ts +49 -49
  69. package/src/schemas/settings_option.schema.ts +41 -41
  70. package/src/schemas/simple_rooms.schema.ts +49 -49
  71. package/src/schemas/tournament_many_tables_rooms.schema.ts +87 -87
  72. package/src/schemas/tournament_one_table_rooms.schema.ts +84 -84
  73. package/src/schemas/user.fb.schema.ts +33 -33
  74. package/src/schemas/user.google.schema.ts +24 -24
  75. package/src/schemas/user.ok.schema.ts +53 -53
  76. package/src/schemas/user.schema.ts +160 -160
  77. package/src/schemas/user.tg.schema.ts +30 -30
  78. package/src/schemas/user.vk.schema.ts +70 -70
  79. package/src/schemas/user.ya.schema.ts +24 -24
  80. package/src/schemas/users_achievement.schema.ts +41 -41
  81. package/src/schemas/users_balance.schema.ts +34 -34
  82. package/src/schemas/welcome.schema.ts +37 -37
  83. package/src/utils.ts +3 -3
@@ -1,153 +1,153 @@
1
- import { Injectable } from '@nestjs/common';
2
- import { InjectModel } from '@nestjs/mongoose';
3
- import { Model } from 'mongoose';
4
- import { BulkWriteResult } from 'mongodb';
5
-
6
- import { User, UserDocument } from '../';
7
-
8
- function getFullNameFilter(userName: string) {
9
- const regexpName = {
10
- $regex: userName,
11
- $options: 'i',
12
- };
13
-
14
- return userName
15
- ? { $or: [{ fullName: regexpName }, { fullNameAlias: regexpName }] }
16
- : {};
17
- }
18
-
19
- export type UserGameResultType = {
20
- userId: string;
21
- balanceAdding: number;
22
- experienceAdding: number;
23
- levelAdding: number;
24
- };
25
-
26
- @Injectable()
27
- export class UsersRepository {
28
- constructor(@InjectModel(User.name) private userModel: Model<UserDocument>) {}
29
-
30
- async findById(id: string): Promise<User | null> {
31
- return this.userModel.findById(id).exec();
32
- }
33
-
34
- async findByVKId(vkId: number): Promise<User | null> {
35
- return this.userModel.findOne({ 'vkUser.id': vkId }).exec();
36
- }
37
-
38
- async findByOkId(okId: string): Promise<User | null> {
39
- return this.userModel.findOne({ 'okUser.uid': okId }).exec();
40
- }
41
-
42
- async findByYAId(yaId: string): Promise<User | null> {
43
- return this.userModel.findOne({ 'yaUser.userId': yaId }).exec();
44
- }
45
-
46
- async findByGoogleId(googleId: string): Promise<User | null> {
47
- return this.userModel.findOne({ 'googleUser.userId': googleId }).exec();
48
- }
49
-
50
- async findByFBId(fbId: string): Promise<User | null> {
51
- return this.userModel.findOne({ 'fbUser.playerId': fbId }).exec();
52
- }
53
-
54
- async findByTGId(tgId: number): Promise<User | null> {
55
- return this.userModel.findOne({ 'tgUser.id': tgId }).exec();
56
- }
57
-
58
- async findAndCount(
59
- userName: string,
60
- limit: number,
61
- skip: number,
62
- ): Promise<{
63
- items: Array<User>;
64
- total: number;
65
- }> {
66
- const items = await this.userModel
67
- .find(getFullNameFilter(userName))
68
- .limit(limit)
69
- .skip(skip)
70
- .exec();
71
-
72
- const total = await this.userModel
73
- .find(getFullNameFilter(userName))
74
- .countDocuments()
75
- .exec();
76
-
77
- return { items, total };
78
- }
79
-
80
- async createUser(user: Partial<User>): Promise<User> {
81
- return this.userModel.create(user);
82
- }
83
-
84
- async updateUser(
85
- userId: string,
86
- user: Partial<User>,
87
- balanceAdding?: number,
88
- ): Promise<UserDocument | null> {
89
- delete user.balance;
90
-
91
- return this.userModel
92
- .findByIdAndUpdate(
93
- userId,
94
- {
95
- $set: {
96
- ...user,
97
- },
98
- $inc: { balance: balanceAdding ?? 0 },
99
- },
100
- { new: true },
101
- )
102
- .exec();
103
- }
104
-
105
- async saveGameResult(
106
- usersBalances: Array<UserGameResultType>,
107
- ): Promise<BulkWriteResult> {
108
- return this.userModel.bulkWrite(
109
- usersBalances.map((item) => ({
110
- updateOne: {
111
- filter: { _id: item.userId },
112
- update: {
113
- $inc: {
114
- balance: item.balanceAdding,
115
- experience: item.experienceAdding,
116
- level: item.levelAdding,
117
- },
118
- },
119
- },
120
- })),
121
- );
122
- }
123
-
124
- async addToBalance(
125
- userId: string,
126
- balanceAdding: number,
127
- ): Promise<UserDocument | null> {
128
- return this.userModel
129
- .findByIdAndUpdate(
130
- userId,
131
- {
132
- $inc: { balance: balanceAdding },
133
- },
134
- { new: true },
135
- )
136
- .exec();
137
- }
138
-
139
- async subtractFromBalance(
140
- userId: string,
141
- balanceSubtraction: number,
142
- ): Promise<UserDocument | null> {
143
- return this.userModel
144
- .findByIdAndUpdate(
145
- userId,
146
- {
147
- $inc: { balance: -balanceSubtraction },
148
- },
149
- { new: true },
150
- )
151
- .exec();
152
- }
153
- }
1
+ import { Injectable } from '@nestjs/common';
2
+ import { InjectModel } from '@nestjs/mongoose';
3
+ import { Model } from 'mongoose';
4
+ import { BulkWriteResult } from 'mongodb';
5
+
6
+ import { User, UserDocument } from '../';
7
+
8
+ function getFullNameFilter(userName: string) {
9
+ const regexpName = {
10
+ $regex: userName,
11
+ $options: 'i',
12
+ };
13
+
14
+ return userName
15
+ ? { $or: [{ fullName: regexpName }, { fullNameAlias: regexpName }] }
16
+ : {};
17
+ }
18
+
19
+ export type UserGameResultType = {
20
+ userId: string;
21
+ balanceAdding: number;
22
+ experienceAdding: number;
23
+ levelAdding: number;
24
+ };
25
+
26
+ @Injectable()
27
+ export class UsersRepository {
28
+ constructor(@InjectModel(User.name) private userModel: Model<UserDocument>) {}
29
+
30
+ async findById(id: string): Promise<User | null> {
31
+ return this.userModel.findById(id).exec();
32
+ }
33
+
34
+ async findByVKId(vkId: number): Promise<User | null> {
35
+ return this.userModel.findOne({ 'vkUser.id': vkId }).exec();
36
+ }
37
+
38
+ async findByOkId(okId: string): Promise<User | null> {
39
+ return this.userModel.findOne({ 'okUser.uid': okId }).exec();
40
+ }
41
+
42
+ async findByYAId(yaId: string): Promise<User | null> {
43
+ return this.userModel.findOne({ 'yaUser.userId': yaId }).exec();
44
+ }
45
+
46
+ async findByGoogleId(googleId: string): Promise<User | null> {
47
+ return this.userModel.findOne({ 'googleUser.userId': googleId }).exec();
48
+ }
49
+
50
+ async findByFBId(fbId: string): Promise<User | null> {
51
+ return this.userModel.findOne({ 'fbUser.playerId': fbId }).exec();
52
+ }
53
+
54
+ async findByTGId(tgId: number): Promise<User | null> {
55
+ return this.userModel.findOne({ 'tgUser.id': tgId }).exec();
56
+ }
57
+
58
+ async findAndCount(
59
+ userName: string,
60
+ limit: number,
61
+ skip: number,
62
+ ): Promise<{
63
+ items: Array<User>;
64
+ total: number;
65
+ }> {
66
+ const items = await this.userModel
67
+ .find(getFullNameFilter(userName))
68
+ .limit(limit)
69
+ .skip(skip)
70
+ .exec();
71
+
72
+ const total = await this.userModel
73
+ .find(getFullNameFilter(userName))
74
+ .countDocuments()
75
+ .exec();
76
+
77
+ return { items, total };
78
+ }
79
+
80
+ async createUser(user: Partial<User>): Promise<User> {
81
+ return this.userModel.create(user);
82
+ }
83
+
84
+ async updateUser(
85
+ userId: string,
86
+ user: Partial<User>,
87
+ balanceAdding?: number,
88
+ ): Promise<UserDocument | null> {
89
+ delete user.balance;
90
+
91
+ return this.userModel
92
+ .findByIdAndUpdate(
93
+ userId,
94
+ {
95
+ $set: {
96
+ ...user,
97
+ },
98
+ $inc: { balance: balanceAdding ?? 0 },
99
+ },
100
+ { new: true },
101
+ )
102
+ .exec();
103
+ }
104
+
105
+ async saveGameResult(
106
+ usersBalances: Array<UserGameResultType>,
107
+ ): Promise<BulkWriteResult> {
108
+ return this.userModel.bulkWrite(
109
+ usersBalances.map((item) => ({
110
+ updateOne: {
111
+ filter: { _id: item.userId },
112
+ update: {
113
+ $inc: {
114
+ balance: item.balanceAdding,
115
+ experience: item.experienceAdding,
116
+ level: item.levelAdding,
117
+ },
118
+ },
119
+ },
120
+ })),
121
+ );
122
+ }
123
+
124
+ async addToBalance(
125
+ userId: string,
126
+ balanceAdding: number,
127
+ ): Promise<UserDocument | null> {
128
+ return this.userModel
129
+ .findByIdAndUpdate(
130
+ userId,
131
+ {
132
+ $inc: { balance: balanceAdding },
133
+ },
134
+ { new: true },
135
+ )
136
+ .exec();
137
+ }
138
+
139
+ async subtractFromBalance(
140
+ userId: string,
141
+ balanceSubtraction: number,
142
+ ): Promise<UserDocument | null> {
143
+ return this.userModel
144
+ .findByIdAndUpdate(
145
+ userId,
146
+ {
147
+ $inc: { balance: -balanceSubtraction },
148
+ },
149
+ { new: true },
150
+ )
151
+ .exec();
152
+ }
153
+ }
@@ -1,16 +1,16 @@
1
- import { Injectable } from '@nestjs/common';
2
- import { InjectModel } from '@nestjs/mongoose';
3
- import { Model } from 'mongoose';
4
-
5
- import { Welcome, WelcomeDocument } from '..';
6
-
7
- @Injectable()
8
- export class WelcomeRepository {
9
- constructor(
10
- @InjectModel(Welcome.name) private welcomeModel: Model<WelcomeDocument>,
11
- ) {}
12
-
13
- async findWelcome(game: string): Promise<Welcome | null> {
14
- return this.welcomeModel.findOne({ game }).exec();
15
- }
16
- }
1
+ import { Injectable } from '@nestjs/common';
2
+ import { InjectModel } from '@nestjs/mongoose';
3
+ import { Model } from 'mongoose';
4
+
5
+ import { Welcome, WelcomeDocument } from '..';
6
+
7
+ @Injectable()
8
+ export class WelcomeRepository {
9
+ constructor(
10
+ @InjectModel(Welcome.name) private welcomeModel: Model<WelcomeDocument>,
11
+ ) {}
12
+
13
+ async findWelcome(game: string): Promise<Welcome | null> {
14
+ return this.welcomeModel.findOne({ game }).exec();
15
+ }
16
+ }
@@ -1,40 +1,40 @@
1
- import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
- import { Document, HydratedDocument } from 'mongoose';
3
-
4
- export type AchievementDocument = HydratedDocument<Achievement>;
5
-
6
- @Schema()
7
- export class Achievement {
8
- @Virtual({
9
- get: function (this: Document) {
10
- return this._id.toString();
11
- },
12
- })
13
- readonly achievementId: string;
14
-
15
- @Prop()
16
- title: string;
17
-
18
- @Prop()
19
- titleEn: string;
20
-
21
- @Prop()
22
- description: string;
23
-
24
- @Prop()
25
- descriptionEn: string;
26
-
27
- @Prop()
28
- code: string;
29
-
30
- @Prop()
31
- vkId: string;
32
-
33
- @Prop()
34
- prize: number;
35
-
36
- @Prop()
37
- game?: string;
38
- }
39
-
40
- export const AchievementSchema = SchemaFactory.createForClass(Achievement);
1
+ import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
+ import { Document, HydratedDocument } from 'mongoose';
3
+
4
+ export type AchievementDocument = HydratedDocument<Achievement>;
5
+
6
+ @Schema()
7
+ export class Achievement {
8
+ @Virtual({
9
+ get: function (this: Document) {
10
+ return this._id.toString();
11
+ },
12
+ })
13
+ readonly achievementId: string;
14
+
15
+ @Prop()
16
+ title: string;
17
+
18
+ @Prop()
19
+ titleEn: string;
20
+
21
+ @Prop()
22
+ description: string;
23
+
24
+ @Prop()
25
+ descriptionEn: string;
26
+
27
+ @Prop()
28
+ code: string;
29
+
30
+ @Prop()
31
+ vkId: string;
32
+
33
+ @Prop()
34
+ prize: number;
35
+
36
+ @Prop()
37
+ game?: string;
38
+ }
39
+
40
+ export const AchievementSchema = SchemaFactory.createForClass(Achievement);
@@ -1,37 +1,37 @@
1
- import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
- import { Document, HydratedDocument } from 'mongoose';
3
-
4
- export type ActivityLogDocument = HydratedDocument<ActivityLog>;
5
-
6
- @Schema({ collection: 'activity_log' })
7
- export class ActivityLog {
8
- @Virtual({
9
- get: function (this: Document) {
10
- return this._id.toString();
11
- },
12
- })
13
- readonly activityLogId: string;
14
-
15
- @Prop({ default: new Date() })
16
- date: Date;
17
-
18
- @Prop()
19
- event: string;
20
-
21
- @Prop()
22
- userId: string;
23
-
24
- @Prop()
25
- userName: string;
26
-
27
- @Prop()
28
- amount?: number;
29
-
30
- @Prop()
31
- game: string;
32
-
33
- @Prop()
34
- channels: string;
35
- }
36
-
37
- export const ActivityLogSchema = SchemaFactory.createForClass(ActivityLog);
1
+ import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
+ import { Document, HydratedDocument } from 'mongoose';
3
+
4
+ export type ActivityLogDocument = HydratedDocument<ActivityLog>;
5
+
6
+ @Schema({ collection: 'activity_log' })
7
+ export class ActivityLog {
8
+ @Virtual({
9
+ get: function (this: Document) {
10
+ return this._id.toString();
11
+ },
12
+ })
13
+ readonly activityLogId: string;
14
+
15
+ @Prop({ default: new Date() })
16
+ date: Date;
17
+
18
+ @Prop()
19
+ event: string;
20
+
21
+ @Prop()
22
+ userId: string;
23
+
24
+ @Prop()
25
+ userName: string;
26
+
27
+ @Prop()
28
+ amount?: number;
29
+
30
+ @Prop()
31
+ game: string;
32
+
33
+ @Prop()
34
+ channels: string;
35
+ }
36
+
37
+ export const ActivityLogSchema = SchemaFactory.createForClass(ActivityLog);
@@ -1,22 +1,22 @@
1
- import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
- import { Document, HydratedDocument } from 'mongoose';
3
-
4
- export type AdminDocument = HydratedDocument<Admin>;
5
-
6
- @Schema()
7
- export class Admin {
8
- @Virtual({
9
- get: function (this: Document) {
10
- return this._id.toString();
11
- },
12
- })
13
- readonly adminId: string;
14
-
15
- @Prop()
16
- login: string;
17
-
18
- @Prop()
19
- pass: string;
20
- }
21
-
22
- export const AdminSchema = SchemaFactory.createForClass(Admin);
1
+ import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
+ import { Document, HydratedDocument } from 'mongoose';
3
+
4
+ export type AdminDocument = HydratedDocument<Admin>;
5
+
6
+ @Schema()
7
+ export class Admin {
8
+ @Virtual({
9
+ get: function (this: Document) {
10
+ return this._id.toString();
11
+ },
12
+ })
13
+ readonly adminId: string;
14
+
15
+ @Prop()
16
+ login: string;
17
+
18
+ @Prop()
19
+ pass: string;
20
+ }
21
+
22
+ export const AdminSchema = SchemaFactory.createForClass(Admin);
@@ -1,37 +1,37 @@
1
- import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
- import { Document, HydratedDocument } from 'mongoose';
3
-
4
- export type ArticleDocument = HydratedDocument<Article>;
5
-
6
- @Schema()
7
- export class Article {
8
- @Virtual({
9
- get: function (this: Document) {
10
- return this._id.toString();
11
- },
12
- })
13
- readonly articleId: string;
14
-
15
- @Prop()
16
- title: string;
17
-
18
- @Prop()
19
- titleEn: string;
20
-
21
- @Prop()
22
- text: string;
23
-
24
- @Prop()
25
- textEn: string;
26
-
27
- @Prop()
28
- cover: string;
29
-
30
- @Prop()
31
- createDate: Date;
32
-
33
- @Prop()
34
- keywords: string;
35
- }
36
-
37
- export const ArticleSchema = SchemaFactory.createForClass(Article);
1
+ import { Prop, Schema, SchemaFactory, Virtual } from '@nestjs/mongoose';
2
+ import { Document, HydratedDocument } from 'mongoose';
3
+
4
+ export type ArticleDocument = HydratedDocument<Article>;
5
+
6
+ @Schema()
7
+ export class Article {
8
+ @Virtual({
9
+ get: function (this: Document) {
10
+ return this._id.toString();
11
+ },
12
+ })
13
+ readonly articleId: string;
14
+
15
+ @Prop()
16
+ title: string;
17
+
18
+ @Prop()
19
+ titleEn: string;
20
+
21
+ @Prop()
22
+ text: string;
23
+
24
+ @Prop()
25
+ textEn: string;
26
+
27
+ @Prop()
28
+ cover: string;
29
+
30
+ @Prop()
31
+ createDate: Date;
32
+
33
+ @Prop()
34
+ keywords: string;
35
+ }
36
+
37
+ export const ArticleSchema = SchemaFactory.createForClass(Article);