jp.db.schemas 2.2.8 → 2.2.10

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 (282) hide show
  1. package/dist/index.d.ts.map +1 -1
  2. package/dist/index.js.map +1 -1
  3. package/dist/models/activity-log-user-login.interface.d.ts.map +1 -1
  4. package/dist/models/activity-log.enum.d.ts.map +1 -1
  5. package/dist/models/activity-log.enum.js.map +1 -1
  6. package/dist/models/currency.enum.d.ts.map +1 -1
  7. package/dist/models/currency.enum.js.map +1 -1
  8. package/dist/models/rating-add-bulk-item.interface.d.ts.map +1 -1
  9. package/dist/models/rating-monthly-result.interface.d.ts.map +1 -1
  10. package/dist/models/tournament-participant.interface.d.ts.map +1 -1
  11. package/dist/models/tournament-status.enum.d.ts.map +1 -1
  12. package/dist/models/tournament-status.enum.js.map +1 -1
  13. package/dist/models/tournament-template.enum.d.ts.map +1 -1
  14. package/dist/models/tournament-template.enum.js.map +1 -1
  15. package/dist/models/tournament-winner.interface.d.ts.map +1 -1
  16. package/dist/models/users-balance-reason.enum.d.ts.map +1 -1
  17. package/dist/models/users-balance-reason.enum.js.map +1 -1
  18. package/dist/repositories/achievement.repository.d.ts.map +1 -1
  19. package/dist/repositories/achievement.repository.js +1 -3
  20. package/dist/repositories/achievement.repository.js.map +1 -1
  21. package/dist/repositories/activity-log.repository.d.ts.map +1 -1
  22. package/dist/repositories/activity-log.repository.js +78 -26
  23. package/dist/repositories/activity-log.repository.js.map +1 -1
  24. package/dist/repositories/admin.repository.d.ts.map +1 -1
  25. package/dist/repositories/admin.repository.js +2 -6
  26. package/dist/repositories/admin.repository.js.map +1 -1
  27. package/dist/repositories/article.repository.d.ts.map +1 -1
  28. package/dist/repositories/article.repository.js +3 -13
  29. package/dist/repositories/article.repository.js.map +1 -1
  30. package/dist/repositories/banners.repository.d.ts.map +1 -1
  31. package/dist/repositories/banners.repository.js +7 -12
  32. package/dist/repositories/banners.repository.js.map +1 -1
  33. package/dist/repositories/complains.repository.d.ts.map +1 -1
  34. package/dist/repositories/complains.repository.js +1 -4
  35. package/dist/repositories/complains.repository.js.map +1 -1
  36. package/dist/repositories/daily-bonus.repository.d.ts.map +1 -1
  37. package/dist/repositories/daily-bonus.repository.js +1 -3
  38. package/dist/repositories/daily-bonus.repository.js.map +1 -1
  39. package/dist/repositories/friend.repository.d.ts.map +1 -1
  40. package/dist/repositories/friend.repository.js.map +1 -1
  41. package/dist/repositories/game-result.repository.d.ts.map +1 -1
  42. package/dist/repositories/game-result.repository.js.map +1 -1
  43. package/dist/repositories/game-statistic.repository.d.ts.map +1 -1
  44. package/dist/repositories/game-statistic.repository.js.map +1 -1
  45. package/dist/repositories/index.d.ts +1 -1
  46. package/dist/repositories/index.d.ts.map +1 -1
  47. package/dist/repositories/index.js.map +1 -1
  48. package/dist/repositories/menu.repository.d.ts.map +1 -1
  49. package/dist/repositories/menu.repository.js.map +1 -1
  50. package/dist/repositories/notification.repository.d.ts.map +1 -1
  51. package/dist/repositories/notification.repository.js +6 -9
  52. package/dist/repositories/notification.repository.js.map +1 -1
  53. package/dist/repositories/premium.repository.d.ts.map +1 -1
  54. package/dist/repositories/premium.repository.js +1 -3
  55. package/dist/repositories/premium.repository.js.map +1 -1
  56. package/dist/repositories/products.repository.d.ts.map +1 -1
  57. package/dist/repositories/products.repository.js +1 -3
  58. package/dist/repositories/products.repository.js.map +1 -1
  59. package/dist/repositories/purchase.repository.d.ts.map +1 -1
  60. package/dist/repositories/purchase.repository.js +7 -11
  61. package/dist/repositories/purchase.repository.js.map +1 -1
  62. package/dist/repositories/rating.repository.d.ts.map +1 -1
  63. package/dist/repositories/rating.repository.js +21 -21
  64. package/dist/repositories/rating.repository.js.map +1 -1
  65. package/dist/repositories/rooms.repository.d.ts.map +1 -1
  66. package/dist/repositories/rooms.repository.js +1 -3
  67. package/dist/repositories/rooms.repository.js.map +1 -1
  68. package/dist/repositories/rule.repository.d.ts.map +1 -1
  69. package/dist/repositories/rule.repository.js +1 -3
  70. package/dist/repositories/rule.repository.js.map +1 -1
  71. package/dist/repositories/scheduled-tournaments.repository.d.ts.map +1 -1
  72. package/dist/repositories/scheduled-tournaments.repository.js.map +1 -1
  73. package/dist/repositories/servers.repository.d.ts.map +1 -1
  74. package/dist/repositories/servers.repository.js +1 -3
  75. package/dist/repositories/servers.repository.js.map +1 -1
  76. package/dist/repositories/setting.repository.d.ts.map +1 -1
  77. package/dist/repositories/setting.repository.js.map +1 -1
  78. package/dist/repositories/settings-options.repository.d.ts.map +1 -1
  79. package/dist/repositories/settings-options.repository.js +1 -3
  80. package/dist/repositories/settings-options.repository.js.map +1 -1
  81. package/dist/repositories/simple-rooms.repository.d.ts.map +1 -1
  82. package/dist/repositories/simple-rooms.repository.js +1 -3
  83. package/dist/repositories/simple-rooms.repository.js.map +1 -1
  84. package/dist/repositories/tournament-many-tables-rooms.repository.d.ts.map +1 -1
  85. package/dist/repositories/tournament-many-tables-rooms.repository.js +23 -18
  86. package/dist/repositories/tournament-many-tables-rooms.repository.js.map +1 -1
  87. package/dist/repositories/tournament-one-table-rooms.repository.d.ts.map +1 -1
  88. package/dist/repositories/tournament-one-table-rooms.repository.js +16 -12
  89. package/dist/repositories/tournament-one-table-rooms.repository.js.map +1 -1
  90. package/dist/repositories/users-achievements.repository.d.ts.map +1 -1
  91. package/dist/repositories/users-achievements.repository.js +2 -6
  92. package/dist/repositories/users-achievements.repository.js.map +1 -1
  93. package/dist/repositories/users-balances.repository.d.ts.map +1 -1
  94. package/dist/repositories/users-balances.repository.js +21 -3
  95. package/dist/repositories/users-balances.repository.js.map +1 -1
  96. package/dist/repositories/users.repository.d.ts.map +1 -1
  97. package/dist/repositories/users.repository.js +28 -34
  98. package/dist/repositories/users.repository.js.map +1 -1
  99. package/dist/repositories/welcome.repository.d.ts.map +1 -1
  100. package/dist/repositories/welcome.repository.js +1 -3
  101. package/dist/repositories/welcome.repository.js.map +1 -1
  102. package/dist/schemas/achievement.schema.d.ts.map +1 -1
  103. package/dist/schemas/achievement.schema.js.map +1 -1
  104. package/dist/schemas/activity_log.schema.d.ts.map +1 -1
  105. package/dist/schemas/activity_log.schema.js.map +1 -1
  106. package/dist/schemas/admin.schema.d.ts.map +1 -1
  107. package/dist/schemas/admin.schema.js.map +1 -1
  108. package/dist/schemas/article.schema.d.ts.map +1 -1
  109. package/dist/schemas/article.schema.js.map +1 -1
  110. package/dist/schemas/banner.schema.d.ts.map +1 -1
  111. package/dist/schemas/banner.schema.js.map +1 -1
  112. package/dist/schemas/channel_message.schema.d.ts.map +1 -1
  113. package/dist/schemas/channel_message.schema.js.map +1 -1
  114. package/dist/schemas/complain.schema.d.ts.map +1 -1
  115. package/dist/schemas/complain.schema.js.map +1 -1
  116. package/dist/schemas/daily_bonus.schema.d.ts +4 -16
  117. package/dist/schemas/daily_bonus.schema.d.ts.map +1 -1
  118. package/dist/schemas/daily_bonus.schema.js +4 -12
  119. package/dist/schemas/daily_bonus.schema.js.map +1 -1
  120. package/dist/schemas/feature.schema.d.ts.map +1 -1
  121. package/dist/schemas/feature.schema.js.map +1 -1
  122. package/dist/schemas/friend.schema.d.ts.map +1 -1
  123. package/dist/schemas/friend.schema.js.map +1 -1
  124. package/dist/schemas/game_result.schema.d.ts +14 -14
  125. package/dist/schemas/game_result.schema.d.ts.map +1 -1
  126. package/dist/schemas/game_result.schema.js.map +1 -1
  127. package/dist/schemas/game_statistic.schema.d.ts.map +1 -1
  128. package/dist/schemas/game_statistic.schema.js.map +1 -1
  129. package/dist/schemas/menu.schema.d.ts +2 -12
  130. package/dist/schemas/menu.schema.d.ts.map +1 -1
  131. package/dist/schemas/menu.schema.js +2 -6
  132. package/dist/schemas/menu.schema.js.map +1 -1
  133. package/dist/schemas/notification.schema.d.ts.map +1 -1
  134. package/dist/schemas/notification.schema.js.map +1 -1
  135. package/dist/schemas/premium.schema.d.ts +4 -16
  136. package/dist/schemas/premium.schema.d.ts.map +1 -1
  137. package/dist/schemas/premium.schema.js +4 -12
  138. package/dist/schemas/premium.schema.js.map +1 -1
  139. package/dist/schemas/product.schema.d.ts +12 -72
  140. package/dist/schemas/product.schema.d.ts.map +1 -1
  141. package/dist/schemas/product.schema.js +12 -36
  142. package/dist/schemas/product.schema.js.map +1 -1
  143. package/dist/schemas/purchase.schema.d.ts +20 -20
  144. package/dist/schemas/purchase.schema.d.ts.map +1 -1
  145. package/dist/schemas/purchase.schema.js.map +1 -1
  146. package/dist/schemas/purchase_channel.schema.d.ts.map +1 -1
  147. package/dist/schemas/purchase_channel.schema.js.map +1 -1
  148. package/dist/schemas/rating.schema.d.ts.map +1 -1
  149. package/dist/schemas/rating.schema.js.map +1 -1
  150. package/dist/schemas/rooms.schema.d.ts.map +1 -1
  151. package/dist/schemas/rooms.schema.js.map +1 -1
  152. package/dist/schemas/rule.schema.d.ts +4 -16
  153. package/dist/schemas/rule.schema.d.ts.map +1 -1
  154. package/dist/schemas/rule.schema.js +4 -12
  155. package/dist/schemas/rule.schema.js.map +1 -1
  156. package/dist/schemas/scheduled_tournament.schema.d.ts.map +1 -1
  157. package/dist/schemas/scheduled_tournament.schema.js.map +1 -1
  158. package/dist/schemas/server.schema.d.ts.map +1 -1
  159. package/dist/schemas/server.schema.js.map +1 -1
  160. package/dist/schemas/setting.schema.d.ts +4 -24
  161. package/dist/schemas/setting.schema.d.ts.map +1 -1
  162. package/dist/schemas/setting.schema.js +4 -12
  163. package/dist/schemas/setting.schema.js.map +1 -1
  164. package/dist/schemas/settings_option.schema.d.ts +2 -12
  165. package/dist/schemas/settings_option.schema.d.ts.map +1 -1
  166. package/dist/schemas/settings_option.schema.js +2 -6
  167. package/dist/schemas/settings_option.schema.js.map +1 -1
  168. package/dist/schemas/simple_rooms.schema.d.ts.map +1 -1
  169. package/dist/schemas/simple_rooms.schema.js.map +1 -1
  170. package/dist/schemas/tournament_many_tables_rooms.schema.d.ts.map +1 -1
  171. package/dist/schemas/tournament_many_tables_rooms.schema.js.map +1 -1
  172. package/dist/schemas/tournament_one_table_rooms.schema.d.ts.map +1 -1
  173. package/dist/schemas/tournament_one_table_rooms.schema.js.map +1 -1
  174. package/dist/schemas/user.fb.schema.d.ts.map +1 -1
  175. package/dist/schemas/user.fb.schema.js.map +1 -1
  176. package/dist/schemas/user.google.schema.d.ts.map +1 -1
  177. package/dist/schemas/user.google.schema.js.map +1 -1
  178. package/dist/schemas/user.ok.schema.d.ts +8 -8
  179. package/dist/schemas/user.ok.schema.d.ts.map +1 -1
  180. package/dist/schemas/user.ok.schema.js.map +1 -1
  181. package/dist/schemas/user.schema.d.ts +4 -4
  182. package/dist/schemas/user.schema.d.ts.map +1 -1
  183. package/dist/schemas/user.schema.js +3 -3
  184. package/dist/schemas/user.schema.js.map +1 -1
  185. package/dist/schemas/user.tg.schema.d.ts.map +1 -1
  186. package/dist/schemas/user.tg.schema.js.map +1 -1
  187. package/dist/schemas/user.vk.schema.d.ts.map +1 -1
  188. package/dist/schemas/user.vk.schema.js.map +1 -1
  189. package/dist/schemas/user.ya.schema.d.ts.map +1 -1
  190. package/dist/schemas/user.ya.schema.js.map +1 -1
  191. package/dist/schemas/users_achievement.schema.d.ts.map +1 -1
  192. package/dist/schemas/users_achievement.schema.js.map +1 -1
  193. package/dist/schemas/users_balance.schema.d.ts.map +1 -1
  194. package/dist/schemas/users_balance.schema.js.map +1 -1
  195. package/dist/schemas/welcome.schema.d.ts +4 -16
  196. package/dist/schemas/welcome.schema.d.ts.map +1 -1
  197. package/dist/schemas/welcome.schema.js +4 -12
  198. package/dist/schemas/welcome.schema.js.map +1 -1
  199. package/dist/utils.js.map +1 -1
  200. package/package.json +38 -31
  201. package/readme.md +3 -3
  202. package/src/index.ts +294 -264
  203. package/src/models/account-type.enum.ts +8 -8
  204. package/src/models/activity-log-user-login.interface.ts +10 -10
  205. package/src/models/activity-log.enum.ts +8 -8
  206. package/src/models/currency.enum.ts +6 -6
  207. package/src/models/rating-add-bulk-item.interface.ts +7 -7
  208. package/src/models/rating-monthly-result.interface.ts +11 -11
  209. package/src/models/tournament-participant.interface.ts +5 -5
  210. package/src/models/tournament-status.enum.ts +6 -6
  211. package/src/models/tournament-template.enum.ts +3 -3
  212. package/src/models/tournament-winner.interface.ts +7 -7
  213. package/src/models/users-balance-reason.enum.ts +8 -8
  214. package/src/repositories/achievement.repository.ts +17 -18
  215. package/src/repositories/activity-log.repository.ts +209 -124
  216. package/src/repositories/admin.repository.ts +20 -23
  217. package/src/repositories/article.repository.ts +24 -33
  218. package/src/repositories/banners.repository.ts +60 -60
  219. package/src/repositories/complains.repository.ts +31 -30
  220. package/src/repositories/daily-bonus.repository.ts +32 -26
  221. package/src/repositories/friend.repository.ts +24 -20
  222. package/src/repositories/game-result.repository.ts +19 -15
  223. package/src/repositories/game-statistic.repository.ts +25 -21
  224. package/src/repositories/index.ts +61 -61
  225. package/src/repositories/menu.repository.ts +19 -21
  226. package/src/repositories/notification.repository.ts +59 -54
  227. package/src/repositories/premium.repository.ts +16 -18
  228. package/src/repositories/products.repository.ts +30 -29
  229. package/src/repositories/purchase.repository.ts +111 -115
  230. package/src/repositories/rating.repository.ts +90 -84
  231. package/src/repositories/rooms.repository.ts +14 -17
  232. package/src/repositories/rule.repository.ts +14 -18
  233. package/src/repositories/scheduled-tournaments.repository.ts +35 -30
  234. package/src/repositories/servers.repository.ts +16 -18
  235. package/src/repositories/setting.repository.ts +24 -20
  236. package/src/repositories/settings-options.repository.ts +17 -18
  237. package/src/repositories/simple-rooms.repository.ts +16 -17
  238. package/src/repositories/tournament-many-tables-rooms.repository.ts +171 -146
  239. package/src/repositories/tournament-one-table-rooms.repository.ts +142 -120
  240. package/src/repositories/users-achievements.repository.ts +46 -43
  241. package/src/repositories/users-balances.repository.ts +65 -28
  242. package/src/repositories/users.repository.ts +153 -144
  243. package/src/repositories/welcome.repository.ts +16 -18
  244. package/src/schemas/achievement.schema.ts +40 -40
  245. package/src/schemas/activity_log.schema.ts +37 -37
  246. package/src/schemas/admin.schema.ts +22 -22
  247. package/src/schemas/article.schema.ts +37 -37
  248. package/src/schemas/banner.schema.ts +40 -40
  249. package/src/schemas/channel_message.schema.ts +32 -31
  250. package/src/schemas/complain.schema.ts +46 -46
  251. package/src/schemas/daily_bonus.schema.ts +49 -57
  252. package/src/schemas/feature.schema.ts +28 -28
  253. package/src/schemas/friend.schema.ts +49 -51
  254. package/src/schemas/game_result.schema.ts +68 -68
  255. package/src/schemas/game_statistic.schema.ts +40 -40
  256. package/src/schemas/menu.schema.ts +37 -40
  257. package/src/schemas/notification.schema.ts +61 -61
  258. package/src/schemas/premium.schema.ts +37 -46
  259. package/src/schemas/product.schema.ts +111 -129
  260. package/src/schemas/purchase.schema.ts +61 -61
  261. package/src/schemas/purchase_channel.schema.ts +32 -31
  262. package/src/schemas/rating.schema.ts +37 -37
  263. package/src/schemas/rooms.schema.ts +63 -63
  264. package/src/schemas/rule.schema.ts +37 -46
  265. package/src/schemas/scheduled_tournament.schema.ts +94 -93
  266. package/src/schemas/server.schema.ts +22 -22
  267. package/src/schemas/setting.schema.ts +49 -55
  268. package/src/schemas/settings_option.schema.ts +41 -43
  269. package/src/schemas/simple_rooms.schema.ts +49 -49
  270. package/src/schemas/tournament_many_tables_rooms.schema.ts +87 -84
  271. package/src/schemas/tournament_one_table_rooms.schema.ts +84 -81
  272. package/src/schemas/user.fb.schema.ts +33 -33
  273. package/src/schemas/user.google.schema.ts +24 -24
  274. package/src/schemas/user.ok.schema.ts +53 -52
  275. package/src/schemas/user.schema.ts +160 -158
  276. package/src/schemas/user.tg.schema.ts +30 -30
  277. package/src/schemas/user.vk.schema.ts +70 -70
  278. package/src/schemas/user.ya.schema.ts +24 -24
  279. package/src/schemas/users_achievement.schema.ts +41 -40
  280. package/src/schemas/users_balance.schema.ts +34 -34
  281. package/src/schemas/welcome.schema.ts +37 -46
  282. package/src/utils.ts +3 -3
@@ -1,144 +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 ? { $or: [{ fullName: regexpName }, { fullNameAlias: regexpName }] } : {};
15
- }
16
-
17
- export type UserGameResultType = {
18
- userId: string;
19
- balanceAdding: number;
20
- experienceAdding: number;
21
- levelAdding: number;
22
- }
23
-
24
- @Injectable()
25
- export class UsersRepository {
26
- constructor(@InjectModel(User.name) private userModel: Model<UserDocument>) {
27
- }
28
-
29
- async findById(id: string): Promise<User | null> {
30
- return this.userModel
31
- .findById(id)
32
- .exec();
33
- }
34
-
35
- async findByVKId(vkId: number): Promise<User | null> {
36
- return this.userModel
37
- .findOne({ 'vkUser.id': vkId })
38
- .exec();
39
- }
40
-
41
- async findByOkId(okId: string): Promise<User | null> {
42
- return this.userModel
43
- .findOne({ 'okUser.uid': okId })
44
- .exec();
45
- }
46
-
47
- async findByYAId(yaId: string): Promise<User | null> {
48
- return this.userModel
49
- .findOne({ 'yaUser.userId': yaId })
50
- .exec();
51
- }
52
-
53
- async findByGoogleId(googleId: string): Promise<User | null> {
54
- return this.userModel
55
- .findOne({ 'googleUser.userId': googleId })
56
- .exec();
57
- }
58
-
59
- async findByFBId(fbId: string): Promise<User | null> {
60
- return this.userModel
61
- .findOne({ 'fbUser.playerId': fbId })
62
- .exec();
63
- }
64
-
65
- async findByTGId(tgId: number): Promise<User | null> {
66
- return this.userModel
67
- .findOne({ 'tgUser.id': tgId })
68
- .exec();
69
- }
70
-
71
- async findAndCount(userName: string, limit: number, skip: number): Promise<{
72
- items: Array<User>,
73
- total: number
74
- }> {
75
- const items = await this.userModel
76
- .find(getFullNameFilter(userName))
77
- .limit(limit)
78
- .skip(skip)
79
- .exec();
80
-
81
- const total = await this.userModel
82
- .find(getFullNameFilter(userName))
83
- .countDocuments()
84
- .exec();
85
-
86
- return { items, total };
87
- }
88
-
89
- async createUser(user: Partial<User>): Promise<User> {
90
- return this.userModel.create(user);
91
- }
92
-
93
- async updateUser(userId: string, user: Partial<User>, balanceAdding?: number): Promise<UserDocument | null> {
94
- delete user.balance;
95
-
96
- return this.userModel.findByIdAndUpdate(
97
- userId,
98
- {
99
- $set: {
100
- ...user,
101
- },
102
- $inc: { balance: balanceAdding ?? 0 }
103
- },
104
- { new: true },
105
- ).exec();
106
- }
107
-
108
- async saveGameResult(usersBalances: Array<UserGameResultType>): Promise<BulkWriteResult> {
109
- return this.userModel.bulkWrite(
110
- usersBalances.map((item) => ({
111
- updateOne: {
112
- filter: { _id: item.userId },
113
- update: {
114
- $inc: {
115
- balance: item.balanceAdding,
116
- experience: item.experienceAdding,
117
- level: item.levelAdding,
118
- }
119
- },
120
- },
121
- })),
122
- );
123
- }
124
-
125
- async addToBalance(userId: string, balanceAdding: number): Promise<UserDocument | null> {
126
- return this.userModel.findByIdAndUpdate(
127
- userId,
128
- {
129
- $inc: { balance: balanceAdding }
130
- },
131
- { new: true },
132
- ).exec();
133
- }
134
-
135
- async subtractFromBalance(userId: string, balanceSubtraction: number): Promise<UserDocument | null> {
136
- return this.userModel.findByIdAndUpdate(
137
- userId,
138
- {
139
- $inc: { balance: -balanceSubtraction }
140
- },
141
- { new: true },
142
- ).exec();
143
- }
144
- }
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,18 +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
- import { getChannelRegExpFilter } from '../utils';
7
-
8
- @Injectable()
9
- export class WelcomeRepository {
10
- constructor (@InjectModel(Welcome.name) private welcomeModel: Model<WelcomeDocument>) {
11
- }
12
-
13
- async findWelcome (game: string): Promise<Welcome | null> {
14
- return this.welcomeModel
15
- .findOne({ game })
16
- .exec();
17
- }
18
- }
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);