@takaro/db 0.0.0-next.09a7ca1

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 (677) hide show
  1. package/README.md +1 -0
  2. package/dist/TakaroModel.d.ts +16 -0
  3. package/dist/TakaroModel.d.ts.map +1 -0
  4. package/dist/TakaroModel.js +25 -0
  5. package/dist/TakaroModel.js.map +1 -0
  6. package/dist/config.d.ts +120 -0
  7. package/dist/config.d.ts.map +1 -0
  8. package/dist/config.js +99 -0
  9. package/dist/config.js.map +1 -0
  10. package/dist/encryption.d.ts +5 -0
  11. package/dist/encryption.d.ts.map +1 -0
  12. package/dist/encryption.js +23 -0
  13. package/dist/encryption.js.map +1 -0
  14. package/dist/errorTypeGuards.d.ts +3 -0
  15. package/dist/errorTypeGuards.d.ts.map +1 -0
  16. package/dist/errorTypeGuards.js +11 -0
  17. package/dist/errorTypeGuards.js.map +1 -0
  18. package/dist/knex.d.ts +9 -0
  19. package/dist/knex.d.ts.map +1 -0
  20. package/dist/knex.js +50 -0
  21. package/dist/knex.js.map +1 -0
  22. package/dist/main.d.ts +9 -0
  23. package/dist/main.d.ts.map +1 -0
  24. package/dist/main.js +9 -0
  25. package/dist/main.js.map +1 -0
  26. package/dist/migrations/index.d.ts +3 -0
  27. package/dist/migrations/index.d.ts.map +1 -0
  28. package/dist/migrations/index.js +59 -0
  29. package/dist/migrations/index.js.map +1 -0
  30. package/dist/migrations/sql/20220827191938_init.d.ts +4 -0
  31. package/dist/migrations/sql/20220827191938_init.d.ts.map +1 -0
  32. package/dist/migrations/sql/20220827191938_init.js +155 -0
  33. package/dist/migrations/sql/20220827191938_init.js.map +1 -0
  34. package/dist/migrations/sql/20221019173729_settings.d.ts +4 -0
  35. package/dist/migrations/sql/20221019173729_settings.d.ts.map +1 -0
  36. package/dist/migrations/sql/20221019173729_settings.js +61 -0
  37. package/dist/migrations/sql/20221019173729_settings.js.map +1 -0
  38. package/dist/migrations/sql/20221029103554_refactor_function_assignments.d.ts +4 -0
  39. package/dist/migrations/sql/20221029103554_refactor_function_assignments.d.ts.map +1 -0
  40. package/dist/migrations/sql/20221029103554_refactor_function_assignments.js +33 -0
  41. package/dist/migrations/sql/20221029103554_refactor_function_assignments.js.map +1 -0
  42. package/dist/migrations/sql/20221102190532_commands.d.ts +4 -0
  43. package/dist/migrations/sql/20221102190532_commands.d.ts.map +1 -0
  44. package/dist/migrations/sql/20221102190532_commands.js +58 -0
  45. package/dist/migrations/sql/20221102190532_commands.js.map +1 -0
  46. package/dist/migrations/sql/20221203135001-builtin_modules.d.ts +4 -0
  47. package/dist/migrations/sql/20221203135001-builtin_modules.d.ts.map +1 -0
  48. package/dist/migrations/sql/20221203135001-builtin_modules.js +44 -0
  49. package/dist/migrations/sql/20221203135001-builtin_modules.js.map +1 -0
  50. package/dist/migrations/sql/20230308183400-persistent-variables.d.ts +4 -0
  51. package/dist/migrations/sql/20230308183400-persistent-variables.d.ts.map +1 -0
  52. package/dist/migrations/sql/20230308183400-persistent-variables.js +63 -0
  53. package/dist/migrations/sql/20230308183400-persistent-variables.js.map +1 -0
  54. package/dist/migrations/sql/20230314183400-auth-ory.d.ts +4 -0
  55. package/dist/migrations/sql/20230314183400-auth-ory.d.ts.map +1 -0
  56. package/dist/migrations/sql/20230314183400-auth-ory.js +23 -0
  57. package/dist/migrations/sql/20230314183400-auth-ory.js.map +1 -0
  58. package/dist/migrations/sql/20230325156123_command-arguments.d.ts +4 -0
  59. package/dist/migrations/sql/20230325156123_command-arguments.d.ts.map +1 -0
  60. package/dist/migrations/sql/20230325156123_command-arguments.js +19 -0
  61. package/dist/migrations/sql/20230325156123_command-arguments.js.map +1 -0
  62. package/dist/migrations/sql/20230407132022-module-descriptions.d.ts +4 -0
  63. package/dist/migrations/sql/20230407132022-module-descriptions.d.ts.map +1 -0
  64. package/dist/migrations/sql/20230407132022-module-descriptions.js +11 -0
  65. package/dist/migrations/sql/20230407132022-module-descriptions.js.map +1 -0
  66. package/dist/migrations/sql/20230407143733-module-json-schema-config.d.ts +4 -0
  67. package/dist/migrations/sql/20230407143733-module-json-schema-config.d.ts.map +1 -0
  68. package/dist/migrations/sql/20230407143733-module-json-schema-config.js +14 -0
  69. package/dist/migrations/sql/20230407143733-module-json-schema-config.js.map +1 -0
  70. package/dist/migrations/sql/20230407173055-hook-regex-optional.d.ts +4 -0
  71. package/dist/migrations/sql/20230407173055-hook-regex-optional.d.ts.map +1 -0
  72. package/dist/migrations/sql/20230407173055-hook-regex-optional.js +11 -0
  73. package/dist/migrations/sql/20230407173055-hook-regex-optional.js.map +1 -0
  74. package/dist/migrations/sql/20230415154935-cronjob-configs.d.ts +4 -0
  75. package/dist/migrations/sql/20230415154935-cronjob-configs.d.ts.map +1 -0
  76. package/dist/migrations/sql/20230415154935-cronjob-configs.js +16 -0
  77. package/dist/migrations/sql/20230415154935-cronjob-configs.js.map +1 -0
  78. package/dist/migrations/sql/20230503132906-variables-extra-meta.d.ts +4 -0
  79. package/dist/migrations/sql/20230503132906-variables-extra-meta.d.ts.map +1 -0
  80. package/dist/migrations/sql/20230503132906-variables-extra-meta.js +26 -0
  81. package/dist/migrations/sql/20230503132906-variables-extra-meta.js.map +1 -0
  82. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.d.ts +4 -0
  83. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.d.ts.map +1 -0
  84. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js +8 -0
  85. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js.map +1 -0
  86. package/dist/migrations/sql/20230617081049-discordId-for-users.d.ts +4 -0
  87. package/dist/migrations/sql/20230617081049-discordId-for-users.d.ts.map +1 -0
  88. package/dist/migrations/sql/20230617081049-discordId-for-users.js +14 -0
  89. package/dist/migrations/sql/20230617081049-discordId-for-users.js.map +1 -0
  90. package/dist/migrations/sql/20230618053611-discord-funtionality.d.ts +4 -0
  91. package/dist/migrations/sql/20230618053611-discord-funtionality.d.ts.map +1 -0
  92. package/dist/migrations/sql/20230618053611-discord-funtionality.js +26 -0
  93. package/dist/migrations/sql/20230618053611-discord-funtionality.js.map +1 -0
  94. package/dist/migrations/sql/20230622192402-discord-hooks.d.ts +4 -0
  95. package/dist/migrations/sql/20230622192402-discord-hooks.d.ts.map +1 -0
  96. package/dist/migrations/sql/20230622192402-discord-hooks.js +14 -0
  97. package/dist/migrations/sql/20230622192402-discord-hooks.js.map +1 -0
  98. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.d.ts +4 -0
  99. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.d.ts.map +1 -0
  100. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js +19 -0
  101. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js.map +1 -0
  102. package/dist/migrations/sql/20230710174340-events.d.ts +4 -0
  103. package/dist/migrations/sql/20230710174340-events.d.ts.map +1 -0
  104. package/dist/migrations/sql/20230710174340-events.js +16 -0
  105. package/dist/migrations/sql/20230710174340-events.js.map +1 -0
  106. package/dist/migrations/sql/20230712061220-roles-permissions-extension.d.ts +4 -0
  107. package/dist/migrations/sql/20230712061220-roles-permissions-extension.d.ts.map +1 -0
  108. package/dist/migrations/sql/20230712061220-roles-permissions-extension.js +43 -0
  109. package/dist/migrations/sql/20230712061220-roles-permissions-extension.js.map +1 -0
  110. package/dist/migrations/sql/20230713184927-variables-modulescoped.d.ts +4 -0
  111. package/dist/migrations/sql/20230713184927-variables-modulescoped.d.ts.map +1 -0
  112. package/dist/migrations/sql/20230713184927-variables-modulescoped.js +27 -0
  113. package/dist/migrations/sql/20230713184927-variables-modulescoped.js.map +1 -0
  114. package/dist/migrations/sql/20230714045136-domain-index.d.ts +4 -0
  115. package/dist/migrations/sql/20230714045136-domain-index.d.ts.map +1 -0
  116. package/dist/migrations/sql/20230714045136-domain-index.js +37 -0
  117. package/dist/migrations/sql/20230714045136-domain-index.js.map +1 -0
  118. package/dist/migrations/sql/20230714045727-events-index.d.ts +4 -0
  119. package/dist/migrations/sql/20230714045727-events-index.d.ts.map +1 -0
  120. package/dist/migrations/sql/20230714045727-events-index.js +17 -0
  121. package/dist/migrations/sql/20230714045727-events-index.js.map +1 -0
  122. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.d.ts +4 -0
  123. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.d.ts.map +1 -0
  124. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js +32 -0
  125. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js.map +1 -0
  126. package/dist/migrations/sql/20230724062109-roles-constraints.d.ts +4 -0
  127. package/dist/migrations/sql/20230724062109-roles-constraints.d.ts.map +1 -0
  128. package/dist/migrations/sql/20230724062109-roles-constraints.js +14 -0
  129. package/dist/migrations/sql/20230724062109-roles-constraints.js.map +1 -0
  130. package/dist/migrations/sql/20230811095701-userId-on-events.d.ts +4 -0
  131. package/dist/migrations/sql/20230811095701-userId-on-events.d.ts.map +1 -0
  132. package/dist/migrations/sql/20230811095701-userId-on-events.js +12 -0
  133. package/dist/migrations/sql/20230811095701-userId-on-events.js.map +1 -0
  134. package/dist/migrations/sql/20230921123717-count-for-permissions.d.ts +4 -0
  135. package/dist/migrations/sql/20230921123717-count-for-permissions.d.ts.map +1 -0
  136. package/dist/migrations/sql/20230921123717-count-for-permissions.js +84 -0
  137. package/dist/migrations/sql/20230921123717-count-for-permissions.js.map +1 -0
  138. package/dist/migrations/sql/20231111102812-details-system-permissions.d.ts +37 -0
  139. package/dist/migrations/sql/20231111102812-details-system-permissions.d.ts.map +1 -0
  140. package/dist/migrations/sql/20231111102812-details-system-permissions.js +179 -0
  141. package/dist/migrations/sql/20231111102812-details-system-permissions.js.map +1 -0
  142. package/dist/migrations/sql/20231114151343-system-roles.d.ts +4 -0
  143. package/dist/migrations/sql/20231114151343-system-roles.d.ts.map +1 -0
  144. package/dist/migrations/sql/20231114151343-system-roles.js +41 -0
  145. package/dist/migrations/sql/20231114151343-system-roles.js.map +1 -0
  146. package/dist/migrations/sql/20231118082301-add-new-permissions.d.ts +37 -0
  147. package/dist/migrations/sql/20231118082301-add-new-permissions.d.ts.map +1 -0
  148. package/dist/migrations/sql/20231118082301-add-new-permissions.js +186 -0
  149. package/dist/migrations/sql/20231118082301-add-new-permissions.js.map +1 -0
  150. package/dist/migrations/sql/20231119115037-timedRoles.d.ts +4 -0
  151. package/dist/migrations/sql/20231119115037-timedRoles.d.ts.map +1 -0
  152. package/dist/migrations/sql/20231119115037-timedRoles.js +19 -0
  153. package/dist/migrations/sql/20231119115037-timedRoles.js.map +1 -0
  154. package/dist/migrations/sql/20231123150854-economy-base.d.ts +4 -0
  155. package/dist/migrations/sql/20231123150854-economy-base.d.ts.map +1 -0
  156. package/dist/migrations/sql/20231123150854-economy-base.js +13 -0
  157. package/dist/migrations/sql/20231123150854-economy-base.js.map +1 -0
  158. package/dist/migrations/sql/20231123171611-economy-settings.d.ts +4 -0
  159. package/dist/migrations/sql/20231123171611-economy-settings.d.ts.map +1 -0
  160. package/dist/migrations/sql/20231123171611-economy-settings.js +13 -0
  161. package/dist/migrations/sql/20231123171611-economy-settings.js.map +1 -0
  162. package/dist/migrations/sql/20231124140441-json-module-assignments.d.ts +4 -0
  163. package/dist/migrations/sql/20231124140441-json-module-assignments.d.ts.map +1 -0
  164. package/dist/migrations/sql/20231124140441-json-module-assignments.js +25 -0
  165. package/dist/migrations/sql/20231124140441-json-module-assignments.js.map +1 -0
  166. package/dist/migrations/sql/20231208114507-settings-refactor.d.ts +4 -0
  167. package/dist/migrations/sql/20231208114507-settings-refactor.d.ts.map +1 -0
  168. package/dist/migrations/sql/20231208114507-settings-refactor.js +95 -0
  169. package/dist/migrations/sql/20231208114507-settings-refactor.js.map +1 -0
  170. package/dist/migrations/sql/20231208171234-game-items.d.ts +4 -0
  171. package/dist/migrations/sql/20231208171234-game-items.d.ts.map +1 -0
  172. package/dist/migrations/sql/20231208171234-game-items.js +18 -0
  173. package/dist/migrations/sql/20231208171234-game-items.js.map +1 -0
  174. package/dist/migrations/sql/20231216100720-player-inventory.d.ts +4 -0
  175. package/dist/migrations/sql/20231216100720-player-inventory.d.ts.map +1 -0
  176. package/dist/migrations/sql/20231216100720-player-inventory.js +14 -0
  177. package/dist/migrations/sql/20231216100720-player-inventory.js.map +1 -0
  178. package/dist/migrations/sql/20231222180438-steam-data.d.ts +4 -0
  179. package/dist/migrations/sql/20231222180438-steam-data.d.ts.map +1 -0
  180. package/dist/migrations/sql/20231222180438-steam-data.js +25 -0
  181. package/dist/migrations/sql/20231222180438-steam-data.js.map +1 -0
  182. package/dist/migrations/sql/20231223132631-pog-online.d.ts +4 -0
  183. package/dist/migrations/sql/20231223132631-pog-online.d.ts.map +1 -0
  184. package/dist/migrations/sql/20231223132631-pog-online.js +11 -0
  185. package/dist/migrations/sql/20231223132631-pog-online.js.map +1 -0
  186. package/dist/migrations/sql/20231223212031-unique-index-item-def.d.ts +4 -0
  187. package/dist/migrations/sql/20231223212031-unique-index-item-def.d.ts.map +1 -0
  188. package/dist/migrations/sql/20231223212031-unique-index-item-def.js +24 -0
  189. package/dist/migrations/sql/20231223212031-unique-index-item-def.js.map +1 -0
  190. package/dist/migrations/sql/20231224135126-gameserver-online-status.d.ts +4 -0
  191. package/dist/migrations/sql/20231224135126-gameserver-online-status.d.ts.map +1 -0
  192. package/dist/migrations/sql/20231224135126-gameserver-online-status.js +11 -0
  193. package/dist/migrations/sql/20231224135126-gameserver-online-status.js.map +1 -0
  194. package/dist/migrations/sql/20231224155226-unique-pog.d.ts +4 -0
  195. package/dist/migrations/sql/20231224155226-unique-pog.d.ts.map +1 -0
  196. package/dist/migrations/sql/20231224155226-unique-pog.js +24 -0
  197. package/dist/migrations/sql/20231224155226-unique-pog.js.map +1 -0
  198. package/dist/migrations/sql/20231225140650-extra-ip-info.d.ts +4 -0
  199. package/dist/migrations/sql/20231225140650-extra-ip-info.d.ts.map +1 -0
  200. package/dist/migrations/sql/20231225140650-extra-ip-info.js +23 -0
  201. package/dist/migrations/sql/20231225140650-extra-ip-info.js.map +1 -0
  202. package/dist/migrations/sql/20231227144315-unique-constraints-player.d.ts +4 -0
  203. package/dist/migrations/sql/20231227144315-unique-constraints-player.d.ts.map +1 -0
  204. package/dist/migrations/sql/20231227144315-unique-constraints-player.js +67 -0
  205. package/dist/migrations/sql/20231227144315-unique-constraints-player.js.map +1 -0
  206. package/dist/migrations/sql/20231229144707-more-player-constraints.d.ts +4 -0
  207. package/dist/migrations/sql/20231229144707-more-player-constraints.d.ts.map +1 -0
  208. package/dist/migrations/sql/20231229144707-more-player-constraints.js +17 -0
  209. package/dist/migrations/sql/20231229144707-more-player-constraints.js.map +1 -0
  210. package/dist/migrations/sql/20240101162751-add-settings-constraint.d.ts +4 -0
  211. package/dist/migrations/sql/20240101162751-add-settings-constraint.d.ts.map +1 -0
  212. package/dist/migrations/sql/20240101162751-add-settings-constraint.js +34 -0
  213. package/dist/migrations/sql/20240101162751-add-settings-constraint.js.map +1 -0
  214. package/dist/migrations/sql/20240105130846-remove-some-module-perms.d.ts +4 -0
  215. package/dist/migrations/sql/20240105130846-remove-some-module-perms.d.ts.map +1 -0
  216. package/dist/migrations/sql/20240105130846-remove-some-module-perms.js +80 -0
  217. package/dist/migrations/sql/20240105130846-remove-some-module-perms.js.map +1 -0
  218. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.d.ts +4 -0
  219. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.d.ts.map +1 -0
  220. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js +11 -0
  221. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js.map +1 -0
  222. package/dist/migrations/sql/20240119152426-remove-hook-check.d.ts +4 -0
  223. package/dist/migrations/sql/20240119152426-remove-hook-check.d.ts.map +1 -0
  224. package/dist/migrations/sql/20240119152426-remove-hook-check.js +14 -0
  225. package/dist/migrations/sql/20240119152426-remove-hook-check.js.map +1 -0
  226. package/dist/migrations/sql/20240121142329-move-ip-history.d.ts +4 -0
  227. package/dist/migrations/sql/20240121142329-move-ip-history.d.ts.map +1 -0
  228. package/dist/migrations/sql/20240121142329-move-ip-history.js +44 -0
  229. package/dist/migrations/sql/20240121142329-move-ip-history.js.map +1 -0
  230. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.d.ts +4 -0
  231. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.d.ts.map +1 -0
  232. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js +13 -0
  233. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js.map +1 -0
  234. package/dist/migrations/sql/20240216120143-domain-state.d.ts +4 -0
  235. package/dist/migrations/sql/20240216120143-domain-state.d.ts.map +1 -0
  236. package/dist/migrations/sql/20240216120143-domain-state.js +11 -0
  237. package/dist/migrations/sql/20240216120143-domain-state.js.map +1 -0
  238. package/dist/migrations/sql/20240229141340-looser-fks-events.d.ts +4 -0
  239. package/dist/migrations/sql/20240229141340-looser-fks-events.d.ts.map +1 -0
  240. package/dist/migrations/sql/20240229141340-looser-fks-events.js +18 -0
  241. package/dist/migrations/sql/20240229141340-looser-fks-events.js.map +1 -0
  242. package/dist/migrations/sql/20240301063505-module-functions.d.ts +4 -0
  243. package/dist/migrations/sql/20240301063505-module-functions.d.ts.map +1 -0
  244. package/dist/migrations/sql/20240301063505-module-functions.js +14 -0
  245. package/dist/migrations/sql/20240301063505-module-functions.js.map +1 -0
  246. package/dist/migrations/sql/20240613175009-lastseen-users-pog.d.ts +4 -0
  247. package/dist/migrations/sql/20240613175009-lastseen-users-pog.d.ts.map +1 -0
  248. package/dist/migrations/sql/20240613175009-lastseen-users-pog.js +17 -0
  249. package/dist/migrations/sql/20240613175009-lastseen-users-pog.js.map +1 -0
  250. package/dist/migrations/sql/20240614143517-shop.d.ts +4 -0
  251. package/dist/migrations/sql/20240614143517-shop.d.ts.map +1 -0
  252. package/dist/migrations/sql/20240614143517-shop.js +29 -0
  253. package/dist/migrations/sql/20240614143517-shop.js.map +1 -0
  254. package/dist/migrations/sql/20240615145045-user-player-link.d.ts +4 -0
  255. package/dist/migrations/sql/20240615145045-user-player-link.d.ts.map +1 -0
  256. package/dist/migrations/sql/20240615145045-user-player-link.js +17 -0
  257. package/dist/migrations/sql/20240615145045-user-player-link.js.map +1 -0
  258. package/dist/migrations/sql/20240622132552-fix-ip-history-fk.d.ts +4 -0
  259. package/dist/migrations/sql/20240622132552-fix-ip-history-fk.d.ts.map +1 -0
  260. package/dist/migrations/sql/20240622132552-fix-ip-history-fk.js +11 -0
  261. package/dist/migrations/sql/20240622132552-fix-ip-history-fk.js.map +1 -0
  262. package/dist/migrations/sql/20240626200803-player-inventory-idx.d.ts +4 -0
  263. package/dist/migrations/sql/20240626200803-player-inventory-idx.d.ts.map +1 -0
  264. package/dist/migrations/sql/20240626200803-player-inventory-idx.js +11 -0
  265. package/dist/migrations/sql/20240626200803-player-inventory-idx.js.map +1 -0
  266. package/dist/migrations/sql/20240628174914-shop-orders.d.ts +4 -0
  267. package/dist/migrations/sql/20240628174914-shop-orders.d.ts.map +1 -0
  268. package/dist/migrations/sql/20240628174914-shop-orders.js +16 -0
  269. package/dist/migrations/sql/20240628174914-shop-orders.js.map +1 -0
  270. package/dist/migrations/sql/20240705140358-teleports-public-refactor.d.ts +4 -0
  271. package/dist/migrations/sql/20240705140358-teleports-public-refactor.d.ts.map +1 -0
  272. package/dist/migrations/sql/20240705140358-teleports-public-refactor.js +26 -0
  273. package/dist/migrations/sql/20240705140358-teleports-public-refactor.js.map +1 -0
  274. package/dist/migrations/sql/20240710181429-events-name-idx.d.ts +4 -0
  275. package/dist/migrations/sql/20240710181429-events-name-idx.d.ts.map +1 -0
  276. package/dist/migrations/sql/20240710181429-events-name-idx.js +11 -0
  277. package/dist/migrations/sql/20240710181429-events-name-idx.js.map +1 -0
  278. package/dist/migrations/sql/20240711181423-shop-orders-multi-listing.d.ts +4 -0
  279. package/dist/migrations/sql/20240711181423-shop-orders-multi-listing.d.ts.map +1 -0
  280. package/dist/migrations/sql/20240711181423-shop-orders-multi-listing.js +26 -0
  281. package/dist/migrations/sql/20240711181423-shop-orders-multi-listing.js.map +1 -0
  282. package/dist/migrations/sql/20240718121004-delete-read-gameservers-perm.d.ts +4 -0
  283. package/dist/migrations/sql/20240718121004-delete-read-gameservers-perm.d.ts.map +1 -0
  284. package/dist/migrations/sql/20240718121004-delete-read-gameservers-perm.js +7 -0
  285. package/dist/migrations/sql/20240718121004-delete-read-gameservers-perm.js.map +1 -0
  286. package/dist/migrations/sql/20240718150807-listing-deleted-and-draft-status.d.ts +4 -0
  287. package/dist/migrations/sql/20240718150807-listing-deleted-and-draft-status.d.ts.map +1 -0
  288. package/dist/migrations/sql/20240718150807-listing-deleted-and-draft-status.js +13 -0
  289. package/dist/migrations/sql/20240718150807-listing-deleted-and-draft-status.js.map +1 -0
  290. package/dist/migrations/sql/20240720135010-acting-user-and-module.d.ts +4 -0
  291. package/dist/migrations/sql/20240720135010-acting-user-and-module.d.ts.map +1 -0
  292. package/dist/migrations/sql/20240720135010-acting-user-and-module.js +19 -0
  293. package/dist/migrations/sql/20240720135010-acting-user-and-module.js.map +1 -0
  294. package/dist/migrations/sql/20240811061243-domain-rate-limit-setting.d.ts +4 -0
  295. package/dist/migrations/sql/20240811061243-domain-rate-limit-setting.d.ts.map +1 -0
  296. package/dist/migrations/sql/20240811061243-domain-rate-limit-setting.js +14 -0
  297. package/dist/migrations/sql/20240811061243-domain-rate-limit-setting.js.map +1 -0
  298. package/dist/migrations/sql/20240814133931-domain-ext-ref.d.ts +4 -0
  299. package/dist/migrations/sql/20240814133931-domain-ext-ref.d.ts.map +1 -0
  300. package/dist/migrations/sql/20240814133931-domain-ext-ref.js +16 -0
  301. package/dist/migrations/sql/20240814133931-domain-ext-ref.js.map +1 -0
  302. package/dist/migrations/sql/20240816171220-player-steam-level.d.ts +4 -0
  303. package/dist/migrations/sql/20240816171220-player-steam-level.d.ts.map +1 -0
  304. package/dist/migrations/sql/20240816171220-player-steam-level.js +11 -0
  305. package/dist/migrations/sql/20240816171220-player-steam-level.js.map +1 -0
  306. package/dist/migrations/sql/20240830081157-variable-expiry.d.ts +4 -0
  307. package/dist/migrations/sql/20240830081157-variable-expiry.d.ts.map +1 -0
  308. package/dist/migrations/sql/20240830081157-variable-expiry.js +11 -0
  309. package/dist/migrations/sql/20240830081157-variable-expiry.js.map +1 -0
  310. package/dist/migrations/sql/20240906125101-gameserver-enable.d.ts +4 -0
  311. package/dist/migrations/sql/20240906125101-gameserver-enable.d.ts.map +1 -0
  312. package/dist/migrations/sql/20240906125101-gameserver-enable.js +11 -0
  313. package/dist/migrations/sql/20240906125101-gameserver-enable.js.map +1 -0
  314. package/dist/migrations/sql/20240908185212-domain-name-not-unique.d.ts +4 -0
  315. package/dist/migrations/sql/20240908185212-domain-name-not-unique.d.ts.map +1 -0
  316. package/dist/migrations/sql/20240908185212-domain-name-not-unique.js +9 -0
  317. package/dist/migrations/sql/20240908185212-domain-name-not-unique.js.map +1 -0
  318. package/dist/migrations/sql/20240922110414-player-playtime.d.ts +4 -0
  319. package/dist/migrations/sql/20240922110414-player-playtime.d.ts.map +1 -0
  320. package/dist/migrations/sql/20240922110414-player-playtime.js +11 -0
  321. package/dist/migrations/sql/20240922110414-player-playtime.js.map +1 -0
  322. package/dist/migrations/sql/20240922133738-add-bans.d.ts +4 -0
  323. package/dist/migrations/sql/20240922133738-add-bans.d.ts.map +1 -0
  324. package/dist/migrations/sql/20240922133738-add-bans.js +20 -0
  325. package/dist/migrations/sql/20240922133738-add-bans.js.map +1 -0
  326. package/dist/migrations/sql/20240929090313-global-playtime.d.ts +4 -0
  327. package/dist/migrations/sql/20240929090313-global-playtime.d.ts.map +1 -0
  328. package/dist/migrations/sql/20240929090313-global-playtime.js +11 -0
  329. package/dist/migrations/sql/20240929090313-global-playtime.js.map +1 -0
  330. package/dist/migrations/sql/20240929143849-player-name-null.d.ts +4 -0
  331. package/dist/migrations/sql/20240929143849-player-name-null.d.ts.map +1 -0
  332. package/dist/migrations/sql/20240929143849-player-name-null.js +11 -0
  333. package/dist/migrations/sql/20240929143849-player-name-null.js.map +1 -0
  334. package/dist/migrations/sql/20241012183754-shop-orders-belong-to-player.d.ts +4 -0
  335. package/dist/migrations/sql/20241012183754-shop-orders-belong-to-player.d.ts.map +1 -0
  336. package/dist/migrations/sql/20241012183754-shop-orders-belong-to-player.js +38 -0
  337. package/dist/migrations/sql/20241012183754-shop-orders-belong-to-player.js.map +1 -0
  338. package/dist/migrations/sql/20241013173159-add-indexen-for-moduleId.d.ts +4 -0
  339. package/dist/migrations/sql/20241013173159-add-indexen-for-moduleId.d.ts.map +1 -0
  340. package/dist/migrations/sql/20241013173159-add-indexen-for-moduleId.js +52 -0
  341. package/dist/migrations/sql/20241013173159-add-indexen-for-moduleId.js.map +1 -0
  342. package/dist/migrations/sql/20241020133133-make-listing-name-required.d.ts +4 -0
  343. package/dist/migrations/sql/20241020133133-make-listing-name-required.d.ts.map +1 -0
  344. package/dist/migrations/sql/20241020133133-make-listing-name-required.js +13 -0
  345. package/dist/migrations/sql/20241020133133-make-listing-name-required.js.map +1 -0
  346. package/dist/migrations/sql/20241024164331-events-fk-fix.d.ts +4 -0
  347. package/dist/migrations/sql/20241024164331-events-fk-fix.d.ts.map +1 -0
  348. package/dist/migrations/sql/20241024164331-events-fk-fix.js +14 -0
  349. package/dist/migrations/sql/20241024164331-events-fk-fix.js.map +1 -0
  350. package/dist/migrations/sql/20241030130613-index-for-roleId.d.ts +4 -0
  351. package/dist/migrations/sql/20241030130613-index-for-roleId.d.ts.map +1 -0
  352. package/dist/migrations/sql/20241030130613-index-for-roleId.js +25 -0
  353. package/dist/migrations/sql/20241030130613-index-for-roleId.js.map +1 -0
  354. package/dist/migrations/sql/20241205201123-gameserver-deletedAt.d.ts +4 -0
  355. package/dist/migrations/sql/20241205201123-gameserver-deletedAt.d.ts.map +1 -0
  356. package/dist/migrations/sql/20241205201123-gameserver-deletedAt.js +11 -0
  357. package/dist/migrations/sql/20241205201123-gameserver-deletedAt.js.map +1 -0
  358. package/dist/migrations/sql/20241330200212-module-versions.d.ts +4 -0
  359. package/dist/migrations/sql/20241330200212-module-versions.d.ts.map +1 -0
  360. package/dist/migrations/sql/20241330200212-module-versions.js +329 -0
  361. package/dist/migrations/sql/20241330200212-module-versions.js.map +1 -0
  362. package/dist/migrations/sql/20250112102308-generic-gameserver.d.ts +4 -0
  363. package/dist/migrations/sql/20250112102308-generic-gameserver.d.ts.map +1 -0
  364. package/dist/migrations/sql/20250112102308-generic-gameserver.js +47 -0
  365. package/dist/migrations/sql/20250112102308-generic-gameserver.js.map +1 -0
  366. package/dist/migrations/sql/20250128200529-version-fixes.d.ts +4 -0
  367. package/dist/migrations/sql/20250128200529-version-fixes.d.ts.map +1 -0
  368. package/dist/migrations/sql/20250128200529-version-fixes.js +11 -0
  369. package/dist/migrations/sql/20250128200529-version-fixes.js.map +1 -0
  370. package/dist/migrations/sql/20250131183251-domain-settings.d.ts +4 -0
  371. package/dist/migrations/sql/20250131183251-domain-settings.d.ts.map +1 -0
  372. package/dist/migrations/sql/20250131183251-domain-settings.js +45 -0
  373. package/dist/migrations/sql/20250131183251-domain-settings.js.map +1 -0
  374. package/dist/migrations/sql/20250221130042-variable-length.d.ts +17 -0
  375. package/dist/migrations/sql/20250221130042-variable-length.d.ts.map +1 -0
  376. package/dist/migrations/sql/20250221130042-variable-length.js +30 -0
  377. package/dist/migrations/sql/20250221130042-variable-length.js.map +1 -0
  378. package/dist/migrations/sql/20250221193144-versions-perf-improvements.d.ts +10 -0
  379. package/dist/migrations/sql/20250221193144-versions-perf-improvements.d.ts.map +1 -0
  380. package/dist/migrations/sql/20250221193144-versions-perf-improvements.js +61 -0
  381. package/dist/migrations/sql/20250221193144-versions-perf-improvements.js.map +1 -0
  382. package/dist/migrations/sql/20250223143705-fix-ban-constraint.d.ts +4 -0
  383. package/dist/migrations/sql/20250223143705-fix-ban-constraint.d.ts.map +1 -0
  384. package/dist/migrations/sql/20250223143705-fix-ban-constraint.js +37 -0
  385. package/dist/migrations/sql/20250223143705-fix-ban-constraint.js.map +1 -0
  386. package/dist/migrations/sql/20250305210650-more-module-metadata.d.ts +4 -0
  387. package/dist/migrations/sql/20250305210650-more-module-metadata.d.ts.map +1 -0
  388. package/dist/migrations/sql/20250305210650-more-module-metadata.js +37 -0
  389. package/dist/migrations/sql/20250305210650-more-module-metadata.js.map +1 -0
  390. package/dist/migrations/sql/20250307162855-default-systemconfig.d.ts +4 -0
  391. package/dist/migrations/sql/20250307162855-default-systemconfig.d.ts.map +1 -0
  392. package/dist/migrations/sql/20250307162855-default-systemconfig.js +11 -0
  393. package/dist/migrations/sql/20250307162855-default-systemconfig.js.map +1 -0
  394. package/dist/migrations/sql/20250312184104-unique-external-reference.d.ts +4 -0
  395. package/dist/migrations/sql/20250312184104-unique-external-reference.d.ts.map +1 -0
  396. package/dist/migrations/sql/20250312184104-unique-external-reference.js +11 -0
  397. package/dist/migrations/sql/20250312184104-unique-external-reference.js.map +1 -0
  398. package/dist/migrations/sql/20250314185501-root-users-not-dashboard-user.d.ts +4 -0
  399. package/dist/migrations/sql/20250314185501-root-users-not-dashboard-user.d.ts.map +1 -0
  400. package/dist/migrations/sql/20250314185501-root-users-not-dashboard-user.js +15 -0
  401. package/dist/migrations/sql/20250314185501-root-users-not-dashboard-user.js.map +1 -0
  402. package/dist/migrations/sql/20250315191707-fix-constraint-module-items.d.ts +8 -0
  403. package/dist/migrations/sql/20250315191707-fix-constraint-module-items.d.ts.map +1 -0
  404. package/dist/migrations/sql/20250315191707-fix-constraint-module-items.js +17 -0
  405. package/dist/migrations/sql/20250315191707-fix-constraint-module-items.js.map +1 -0
  406. package/dist/migrations/sql/20250519185149-add-item-indexes.d.ts +13 -0
  407. package/dist/migrations/sql/20250519185149-add-item-indexes.d.ts.map +1 -0
  408. package/dist/migrations/sql/20250519185149-add-item-indexes.js +40 -0
  409. package/dist/migrations/sql/20250519185149-add-item-indexes.js.map +1 -0
  410. package/dist/migrations/sql/20250524054924-tracking.d.ts +4 -0
  411. package/dist/migrations/sql/20250524054924-tracking.d.ts.map +1 -0
  412. package/dist/migrations/sql/20250524054924-tracking.js +75 -0
  413. package/dist/migrations/sql/20250524054924-tracking.js.map +1 -0
  414. package/dist/migrations/sql/20250525135204-ban-reason-length.d.ts +4 -0
  415. package/dist/migrations/sql/20250525135204-ban-reason-length.d.ts.map +1 -0
  416. package/dist/migrations/sql/20250525135204-ban-reason-length.js +30 -0
  417. package/dist/migrations/sql/20250525135204-ban-reason-length.js.map +1 -0
  418. package/dist/migrations/sql/20250605201140-shop-permissions-missing.d.ts +4 -0
  419. package/dist/migrations/sql/20250605201140-shop-permissions-missing.d.ts.map +1 -0
  420. package/dist/migrations/sql/20250605201140-shop-permissions-missing.js +18 -0
  421. package/dist/migrations/sql/20250605201140-shop-permissions-missing.js.map +1 -0
  422. package/dist/migrations/sql/20250606060546-inventory-tracking.d.ts +4 -0
  423. package/dist/migrations/sql/20250606060546-inventory-tracking.d.ts.map +1 -0
  424. package/dist/migrations/sql/20250606060546-inventory-tracking.js +82 -0
  425. package/dist/migrations/sql/20250606060546-inventory-tracking.js.map +1 -0
  426. package/dist/migrations/sql/20250613110835-add-platform-id-to-players.d.ts +4 -0
  427. package/dist/migrations/sql/20250613110835-add-platform-id-to-players.d.ts.map +1 -0
  428. package/dist/migrations/sql/20250613110835-add-platform-id-to-players.js +43 -0
  429. package/dist/migrations/sql/20250613110835-add-platform-id-to-players.js.map +1 -0
  430. package/dist/migrations/sql/20250613203142-add-dimension-to-position.d.ts +4 -0
  431. package/dist/migrations/sql/20250613203142-add-dimension-to-position.d.ts.map +1 -0
  432. package/dist/migrations/sql/20250613203142-add-dimension-to-position.js +21 -0
  433. package/dist/migrations/sql/20250613203142-add-dimension-to-position.js.map +1 -0
  434. package/dist/migrations/sql/20250614113157-entities.d.ts +4 -0
  435. package/dist/migrations/sql/20250614113157-entities.d.ts.map +1 -0
  436. package/dist/migrations/sql/20250614113157-entities.js +36 -0
  437. package/dist/migrations/sql/20250614113157-entities.js.map +1 -0
  438. package/dist/migrations/sql/20250629090822-player-query-performance-indices.d.ts +4 -0
  439. package/dist/migrations/sql/20250629090822-player-query-performance-indices.d.ts.map +1 -0
  440. package/dist/migrations/sql/20250629090822-player-query-performance-indices.js +31 -0
  441. package/dist/migrations/sql/20250629090822-player-query-performance-indices.js.map +1 -0
  442. package/dist/migrations/sql/20250701-command-query-performance-indices.d.ts +4 -0
  443. package/dist/migrations/sql/20250701-command-query-performance-indices.d.ts.map +1 -0
  444. package/dist/migrations/sql/20250701-command-query-performance-indices.js +42 -0
  445. package/dist/migrations/sql/20250701-command-query-performance-indices.js.map +1 -0
  446. package/dist/migrations/sql/20250702181214-platform-id-and-pog-indexes.d.ts +4 -0
  447. package/dist/migrations/sql/20250702181214-platform-id-and-pog-indexes.d.ts.map +1 -0
  448. package/dist/migrations/sql/20250702181214-platform-id-and-pog-indexes.js +27 -0
  449. package/dist/migrations/sql/20250702181214-platform-id-and-pog-indexes.js.map +1 -0
  450. package/dist/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.d.ts +4 -0
  451. package/dist/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.d.ts.map +1 -0
  452. package/dist/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.js +11 -0
  453. package/dist/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.js.map +1 -0
  454. package/dist/migrations/sql/20250707205720-items-permissions-missing.d.ts +4 -0
  455. package/dist/migrations/sql/20250707205720-items-permissions-missing.d.ts.map +1 -0
  456. package/dist/migrations/sql/20250707205720-items-permissions-missing.js +18 -0
  457. package/dist/migrations/sql/20250707205720-items-permissions-missing.js.map +1 -0
  458. package/dist/migrations/sql/20250708095623-command-required-permissions.d.ts +4 -0
  459. package/dist/migrations/sql/20250708095623-command-required-permissions.d.ts.map +1 -0
  460. package/dist/migrations/sql/20250708095623-command-required-permissions.js +11 -0
  461. package/dist/migrations/sql/20250708095623-command-required-permissions.js.map +1 -0
  462. package/dist/migrations/sql/20250710131445-add-shop-categories.d.ts +4 -0
  463. package/dist/migrations/sql/20250710131445-add-shop-categories.d.ts.map +1 -0
  464. package/dist/migrations/sql/20250710131445-add-shop-categories.js +80 -0
  465. package/dist/migrations/sql/20250710131445-add-shop-categories.js.map +1 -0
  466. package/dist/migrations/sql/20250718-fix-player-inventory-history-pk.d.ts +4 -0
  467. package/dist/migrations/sql/20250718-fix-player-inventory-history-pk.d.ts.map +1 -0
  468. package/dist/migrations/sql/20250718-fix-player-inventory-history-pk.js +150 -0
  469. package/dist/migrations/sql/20250718-fix-player-inventory-history-pk.js.map +1 -0
  470. package/dist/migrations/sql/20250719160409-add-module-author-supportedgames.d.ts +8 -0
  471. package/dist/migrations/sql/20250719160409-add-module-author-supportedgames.d.ts.map +1 -0
  472. package/dist/migrations/sql/20250719160409-add-module-author-supportedgames.js +26 -0
  473. package/dist/migrations/sql/20250719160409-add-module-author-supportedgames.js.map +1 -0
  474. package/dist/migrations/sql/20250719175542-add-discord-permissions.d.ts +4 -0
  475. package/dist/migrations/sql/20250719175542-add-discord-permissions.d.ts.map +1 -0
  476. package/dist/migrations/sql/20250719175542-add-discord-permissions.js +18 -0
  477. package/dist/migrations/sql/20250719175542-add-discord-permissions.js.map +1 -0
  478. package/dist/migrations/sql/20250726000000-discord-role-sync.d.ts +4 -0
  479. package/dist/migrations/sql/20250726000000-discord-role-sync.d.ts.map +1 -0
  480. package/dist/migrations/sql/20250726000000-discord-role-sync.js +13 -0
  481. package/dist/migrations/sql/20250726000000-discord-role-sync.js.map +1 -0
  482. package/dist/migrations/sql/20250727092719-add-quality-to-inventory.d.ts +4 -0
  483. package/dist/migrations/sql/20250727092719-add-quality-to-inventory.d.ts.map +1 -0
  484. package/dist/migrations/sql/20250727092719-add-quality-to-inventory.js +11 -0
  485. package/dist/migrations/sql/20250727092719-add-quality-to-inventory.js.map +1 -0
  486. package/dist/migrations/sql/20250802124307-add-playeriphistory-composite-index.d.ts +4 -0
  487. package/dist/migrations/sql/20250802124307-add-playeriphistory-composite-index.d.ts.map +1 -0
  488. package/dist/migrations/sql/20250802124307-add-playeriphistory-composite-index.js +11 -0
  489. package/dist/migrations/sql/20250802124307-add-playeriphistory-composite-index.js.map +1 -0
  490. package/dist/migrations/sql/20250809122020-add-player-name-history.d.ts +4 -0
  491. package/dist/migrations/sql/20250809122020-add-player-name-history.d.ts.map +1 -0
  492. package/dist/migrations/sql/20250809122020-add-player-name-history.js +26 -0
  493. package/dist/migrations/sql/20250809122020-add-player-name-history.js.map +1 -0
  494. package/dist/migrations/sql/20250812163648-add-kpi-performance-indexes.d.ts +4 -0
  495. package/dist/migrations/sql/20250812163648-add-kpi-performance-indexes.d.ts.map +1 -0
  496. package/dist/migrations/sql/20250812163648-add-kpi-performance-indexes.js +17 -0
  497. package/dist/migrations/sql/20250812163648-add-kpi-performance-indexes.js.map +1 -0
  498. package/dist/migrations/sql/20250814163747-shop-order-cascade-delete.d.ts +4 -0
  499. package/dist/migrations/sql/20250814163747-shop-order-cascade-delete.d.ts.map +1 -0
  500. package/dist/migrations/sql/20250814163747-shop-order-cascade-delete.js +23 -0
  501. package/dist/migrations/sql/20250814163747-shop-order-cascade-delete.js.map +1 -0
  502. package/dist/migrations/sql/20250815120000-optimize-shop-analytics-indexes.d.ts +4 -0
  503. package/dist/migrations/sql/20250815120000-optimize-shop-analytics-indexes.d.ts.map +1 -0
  504. package/dist/migrations/sql/20250815120000-optimize-shop-analytics-indexes.js +40 -0
  505. package/dist/migrations/sql/20250815120000-optimize-shop-analytics-indexes.js.map +1 -0
  506. package/dist/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.d.ts +4 -0
  507. package/dist/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.d.ts.map +1 -0
  508. package/dist/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.js +70 -0
  509. package/dist/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.js.map +1 -0
  510. package/dist/migrations/sql/20251101000000-add-deleted-domain-state.d.ts +4 -0
  511. package/dist/migrations/sql/20251101000000-add-deleted-domain-state.d.ts.map +1 -0
  512. package/dist/migrations/sql/20251101000000-add-deleted-domain-state.js +33 -0
  513. package/dist/migrations/sql/20251101000000-add-deleted-domain-state.js.map +1 -0
  514. package/dist/migrations/sql/20251108214824-unique-player-per-server.d.ts +4 -0
  515. package/dist/migrations/sql/20251108214824-unique-player-per-server.d.ts.map +1 -0
  516. package/dist/migrations/sql/20251108214824-unique-player-per-server.js +27 -0
  517. package/dist/migrations/sql/20251108214824-unique-player-per-server.js.map +1 -0
  518. package/dist/migrations/sql/20251115071948-remove-deleted-domain-state.d.ts +4 -0
  519. package/dist/migrations/sql/20251115071948-remove-deleted-domain-state.d.ts.map +1 -0
  520. package/dist/migrations/sql/20251115071948-remove-deleted-domain-state.js +35 -0
  521. package/dist/migrations/sql/20251115071948-remove-deleted-domain-state.js.map +1 -0
  522. package/dist/migrations/sql/20251220000000-inventory-diff-storage.d.ts +4 -0
  523. package/dist/migrations/sql/20251220000000-inventory-diff-storage.d.ts.map +1 -0
  524. package/dist/migrations/sql/20251220000000-inventory-diff-storage.js +147 -0
  525. package/dist/migrations/sql/20251220000000-inventory-diff-storage.js.map +1 -0
  526. package/dist/migrations/util/alterEnum.d.ts +2 -0
  527. package/dist/migrations/util/alterEnum.d.ts.map +1 -0
  528. package/dist/migrations/util/alterEnum.js +8 -0
  529. package/dist/migrations/util/alterEnum.js.map +1 -0
  530. package/dist/queryBuilder.d.ts +43 -0
  531. package/dist/queryBuilder.d.ts.map +1 -0
  532. package/dist/queryBuilder.js +224 -0
  533. package/dist/queryBuilder.js.map +1 -0
  534. package/dist/redis.d.ts +21 -0
  535. package/dist/redis.d.ts.map +1 -0
  536. package/dist/redis.js +50 -0
  537. package/dist/redis.js.map +1 -0
  538. package/package.json +27 -0
  539. package/src/TakaroModel.ts +33 -0
  540. package/src/__tests__/encryption.integration.test.ts +57 -0
  541. package/src/__tests__/queryBuilder.integration.test.ts +208 -0
  542. package/src/config.ts +122 -0
  543. package/src/encryption.ts +26 -0
  544. package/src/errorTypeGuards.ts +11 -0
  545. package/src/knex.ts +59 -0
  546. package/src/main.ts +15 -0
  547. package/src/migrations/index.ts +70 -0
  548. package/src/migrations/sql/20220827191938_init.ts +183 -0
  549. package/src/migrations/sql/20221019173729_settings.ts +70 -0
  550. package/src/migrations/sql/20221029103554_refactor_function_assignments.ts +41 -0
  551. package/src/migrations/sql/20221102190532_commands.ts +66 -0
  552. package/src/migrations/sql/20221203135001-builtin_modules.ts +56 -0
  553. package/src/migrations/sql/20230308183400-persistent-variables.ts +74 -0
  554. package/src/migrations/sql/20230314183400-auth-ory.ts +27 -0
  555. package/src/migrations/sql/20230325156123_command-arguments.ts +24 -0
  556. package/src/migrations/sql/20230407132022-module-descriptions.ts +13 -0
  557. package/src/migrations/sql/20230407143733-module-json-schema-config.ts +16 -0
  558. package/src/migrations/sql/20230407173055-hook-regex-optional.ts +13 -0
  559. package/src/migrations/sql/20230415154935-cronjob-configs.ts +18 -0
  560. package/src/migrations/sql/20230503132906-variables-extra-meta.ts +31 -0
  561. package/src/migrations/sql/20230604130951-fix-hook-eventtypes.ts +12 -0
  562. package/src/migrations/sql/20230617081049-discordId-for-users.ts +16 -0
  563. package/src/migrations/sql/20230618053611-discord-funtionality.ts +34 -0
  564. package/src/migrations/sql/20230622192402-discord-hooks.ts +20 -0
  565. package/src/migrations/sql/20230707081218-playerOnGameServerExtension.ts +21 -0
  566. package/src/migrations/sql/20230710174340-events.ts +21 -0
  567. package/src/migrations/sql/20230712061220-roles-permissions-extension.ts +50 -0
  568. package/src/migrations/sql/20230713184927-variables-modulescoped.ts +32 -0
  569. package/src/migrations/sql/20230714045136-domain-index.ts +40 -0
  570. package/src/migrations/sql/20230714045727-events-index.ts +19 -0
  571. package/src/migrations/sql/20230715102519-module-permissions-extra-fields.ts +38 -0
  572. package/src/migrations/sql/20230724062109-roles-constraints.ts +16 -0
  573. package/src/migrations/sql/20230811095701-userId-on-events.ts +14 -0
  574. package/src/migrations/sql/20230921123717-count-for-permissions.ts +101 -0
  575. package/src/migrations/sql/20231111102812-details-system-permissions.ts +192 -0
  576. package/src/migrations/sql/20231114151343-system-roles.ts +46 -0
  577. package/src/migrations/sql/20231118082301-add-new-permissions.ts +200 -0
  578. package/src/migrations/sql/20231119115037-timedRoles.ts +23 -0
  579. package/src/migrations/sql/20231123150854-economy-base.ts +15 -0
  580. package/src/migrations/sql/20231123171611-economy-settings.ts +15 -0
  581. package/src/migrations/sql/20231124140441-json-module-assignments.ts +29 -0
  582. package/src/migrations/sql/20231208114507-settings-refactor.ts +114 -0
  583. package/src/migrations/sql/20231208171234-game-items.ts +20 -0
  584. package/src/migrations/sql/20231216100720-player-inventory.ts +16 -0
  585. package/src/migrations/sql/20231222180438-steam-data.ts +27 -0
  586. package/src/migrations/sql/20231223132631-pog-online.ts +13 -0
  587. package/src/migrations/sql/20231223212031-unique-index-item-def.ts +27 -0
  588. package/src/migrations/sql/20231224135126-gameserver-online-status.ts +13 -0
  589. package/src/migrations/sql/20231224155226-unique-pog.ts +27 -0
  590. package/src/migrations/sql/20231225140650-extra-ip-info.ts +27 -0
  591. package/src/migrations/sql/20231227144315-unique-constraints-player.ts +74 -0
  592. package/src/migrations/sql/20231229144707-more-player-constraints.ts +20 -0
  593. package/src/migrations/sql/20240101162751-add-settings-constraint.ts +39 -0
  594. package/src/migrations/sql/20240105130846-remove-some-module-perms.ts +104 -0
  595. package/src/migrations/sql/20240116141936-add-ui-schema-to-module.ts +13 -0
  596. package/src/migrations/sql/20240119152426-remove-hook-check.ts +18 -0
  597. package/src/migrations/sql/20240121142329-move-ip-history.ts +53 -0
  598. package/src/migrations/sql/20240202101208-rename-economy-to-economyUtils.ts +15 -0
  599. package/src/migrations/sql/20240216120143-domain-state.ts +13 -0
  600. package/src/migrations/sql/20240229141340-looser-fks-events.ts +20 -0
  601. package/src/migrations/sql/20240301063505-module-functions.ts +17 -0
  602. package/src/migrations/sql/20240613175009-lastseen-users-pog.ts +21 -0
  603. package/src/migrations/sql/20240614143517-shop.ts +39 -0
  604. package/src/migrations/sql/20240615145045-user-player-link.ts +20 -0
  605. package/src/migrations/sql/20240622132552-fix-ip-history-fk.ts +13 -0
  606. package/src/migrations/sql/20240626200803-player-inventory-idx.ts +13 -0
  607. package/src/migrations/sql/20240628174914-shop-orders.ts +20 -0
  608. package/src/migrations/sql/20240705140358-teleports-public-refactor.ts +31 -0
  609. package/src/migrations/sql/20240710181429-events-name-idx.ts +13 -0
  610. package/src/migrations/sql/20240711181423-shop-orders-multi-listing.ts +34 -0
  611. package/src/migrations/sql/20240718121004-delete-read-gameservers-perm.ts +9 -0
  612. package/src/migrations/sql/20240718150807-listing-deleted-and-draft-status.ts +15 -0
  613. package/src/migrations/sql/20240720135010-acting-user-and-module.ts +24 -0
  614. package/src/migrations/sql/20240811061243-domain-rate-limit-setting.ts +16 -0
  615. package/src/migrations/sql/20240814133931-domain-ext-ref.ts +24 -0
  616. package/src/migrations/sql/20240816171220-player-steam-level.ts +14 -0
  617. package/src/migrations/sql/20240830081157-variable-expiry.ts +14 -0
  618. package/src/migrations/sql/20240906125101-gameserver-enable.ts +14 -0
  619. package/src/migrations/sql/20240908185212-domain-name-not-unique.ts +12 -0
  620. package/src/migrations/sql/20240922110414-player-playtime.ts +13 -0
  621. package/src/migrations/sql/20240922133738-add-bans.ts +25 -0
  622. package/src/migrations/sql/20240929090313-global-playtime.ts +13 -0
  623. package/src/migrations/sql/20240929143849-player-name-null.ts +13 -0
  624. package/src/migrations/sql/20241012183754-shop-orders-belong-to-player.ts +44 -0
  625. package/src/migrations/sql/20241013173159-add-indexen-for-moduleId.ts +57 -0
  626. package/src/migrations/sql/20241020133133-make-listing-name-required.ts +16 -0
  627. package/src/migrations/sql/20241024164331-events-fk-fix.ts +16 -0
  628. package/src/migrations/sql/20241030130613-index-for-roleId.ts +31 -0
  629. package/src/migrations/sql/20241205201123-gameserver-deletedAt.ts +13 -0
  630. package/src/migrations/sql/20241330200212-module-versions.ts +384 -0
  631. package/src/migrations/sql/20250112102308-generic-gameserver.ts +55 -0
  632. package/src/migrations/sql/20250128200529-version-fixes.ts +13 -0
  633. package/src/migrations/sql/20250131183251-domain-settings.ts +55 -0
  634. package/src/migrations/sql/20250221130042-variable-length.ts +35 -0
  635. package/src/migrations/sql/20250221193144-versions-perf-improvements.ts +79 -0
  636. package/src/migrations/sql/20250223143705-fix-ban-constraint.ts +43 -0
  637. package/src/migrations/sql/20250305210650-more-module-metadata.ts +49 -0
  638. package/src/migrations/sql/20250307162855-default-systemconfig.ts +13 -0
  639. package/src/migrations/sql/20250312184104-unique-external-reference.ts +13 -0
  640. package/src/migrations/sql/20250314185501-root-users-not-dashboard-user.ts +17 -0
  641. package/src/migrations/sql/20250315191707-fix-constraint-module-items.ts +26 -0
  642. package/src/migrations/sql/20250519185149-add-item-indexes.ts +42 -0
  643. package/src/migrations/sql/20250524054924-tracking.ts +79 -0
  644. package/src/migrations/sql/20250525135204-ban-reason-length.ts +35 -0
  645. package/src/migrations/sql/20250605201140-shop-permissions-missing.ts +20 -0
  646. package/src/migrations/sql/20250606060546-inventory-tracking.ts +96 -0
  647. package/src/migrations/sql/20250613110835-add-platform-id-to-players.ts +51 -0
  648. package/src/migrations/sql/20250613203142-add-dimension-to-position.ts +25 -0
  649. package/src/migrations/sql/20250614113157-entities.ts +40 -0
  650. package/src/migrations/sql/20250629090822-player-query-performance-indices.ts +38 -0
  651. package/src/migrations/sql/20250701-command-query-performance-indices.ts +53 -0
  652. package/src/migrations/sql/20250702181214-platform-id-and-pog-indexes.ts +31 -0
  653. package/src/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.ts +13 -0
  654. package/src/migrations/sql/20250707205720-items-permissions-missing.ts +20 -0
  655. package/src/migrations/sql/20250708095623-command-required-permissions.ts +13 -0
  656. package/src/migrations/sql/20250710131445-add-shop-categories.ts +98 -0
  657. package/src/migrations/sql/20250718-fix-player-inventory-history-pk.ts +161 -0
  658. package/src/migrations/sql/20250719160409-add-module-author-supportedgames.ts +31 -0
  659. package/src/migrations/sql/20250719175542-add-discord-permissions.ts +20 -0
  660. package/src/migrations/sql/20250726000000-discord-role-sync.ts +15 -0
  661. package/src/migrations/sql/20250727092719-add-quality-to-inventory.ts +13 -0
  662. package/src/migrations/sql/20250802124307-add-playeriphistory-composite-index.ts +13 -0
  663. package/src/migrations/sql/20250809122020-add-player-name-history.ts +31 -0
  664. package/src/migrations/sql/20250812163648-add-kpi-performance-indexes.ts +20 -0
  665. package/src/migrations/sql/20250814163747-shop-order-cascade-delete.ts +27 -0
  666. package/src/migrations/sql/20250815120000-optimize-shop-analytics-indexes.ts +46 -0
  667. package/src/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.ts +75 -0
  668. package/src/migrations/sql/20251101000000-add-deleted-domain-state.ts +43 -0
  669. package/src/migrations/sql/20251108214824-unique-player-per-server.ts +30 -0
  670. package/src/migrations/sql/20251115071948-remove-deleted-domain-state.ts +46 -0
  671. package/src/migrations/sql/20251220000000-inventory-diff-storage.ts +164 -0
  672. package/src/migrations/util/alterEnum.ts +9 -0
  673. package/src/queryBuilder.ts +263 -0
  674. package/src/redis.ts +59 -0
  675. package/tsconfig.build.json +14 -0
  676. package/tsconfig.json +8 -0
  677. package/typedoc.json +3 -0
@@ -0,0 +1,17 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('functions', (table) => {
5
+ table.string('name').nullable();
6
+ table.uuid('moduleId').nullable();
7
+ table.foreign('moduleId').references('id').inTable('modules');
8
+ });
9
+ }
10
+
11
+ export async function down(knex: Knex): Promise<void> {
12
+ await knex.schema.dropTable('module_functions');
13
+
14
+ await knex.schema.alterTable('functions', (table) => {
15
+ table.dropColumn('name');
16
+ });
17
+ }
@@ -0,0 +1,21 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('users', (table) => {
5
+ table.timestamp('lastSeen').defaultTo(knex.fn.now()).notNullable();
6
+ });
7
+
8
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
9
+ table.timestamp('lastSeen').defaultTo(knex.fn.now()).notNullable();
10
+ });
11
+ }
12
+
13
+ export async function down(knex: Knex): Promise<void> {
14
+ await knex.schema.alterTable('users', (table) => {
15
+ table.dropColumn('lastSeen');
16
+ });
17
+
18
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
19
+ table.dropColumn('lastSeen');
20
+ });
21
+ }
@@ -0,0 +1,39 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.createTable('shopListing', (table) => {
5
+ table.timestamps(true, true, true);
6
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
7
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
8
+ table.index('domain');
9
+
10
+ table.uuid('gameServerId').references('gameservers.id').onDelete('CASCADE').notNullable();
11
+
12
+ table.uuid('itemId').references('items.id').onDelete('CASCADE');
13
+ table.uuid('functionId').references('functions.id').onDelete('CASCADE');
14
+
15
+ // Either an item or a function must be set
16
+ table.check('("itemId" IS NOT NULL) OR ("functionId" IS NOT NULL)');
17
+
18
+ table.integer('price').notNullable();
19
+
20
+ // Price must be positive and non-zero
21
+ table.check('"price" > 0');
22
+
23
+ table.string('name').nullable();
24
+ });
25
+
26
+ // Listings can only be bought by users with the role
27
+ await knex.schema.createTable('shopListingRole', (table) => {
28
+ table.timestamps(true, true, true);
29
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
30
+
31
+ table.uuid('listingId').references('shopListing.id').onDelete('CASCADE').notNullable();
32
+ table.uuid('roleId').references('roles.id').onDelete('CASCADE').notNullable();
33
+ });
34
+ }
35
+
36
+ export async function down(knex: Knex): Promise<void> {
37
+ await knex.schema.dropTable('shopListingRole');
38
+ await knex.schema.dropTable('shopListing');
39
+ }
@@ -0,0 +1,20 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ // Remove users_idp_id_unique constraint
5
+ //idpId must be unique per domain instead
6
+ await knex.schema.alterTable('users', (table) => {
7
+ table.dropUnique(['idpid']);
8
+ table.unique(['idpId', 'domain']);
9
+
10
+ table.uuid('playerId').references('players.id').onDelete('SET NULL').nullable();
11
+ });
12
+ }
13
+
14
+ export async function down(knex: Knex): Promise<void> {
15
+ await knex.schema.alterTable('users', (table) => {
16
+ table.dropUnique(['idpid', 'domain']);
17
+ table.unique(['idpId']);
18
+ table.dropColumn('playerId');
19
+ });
20
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('playerIpHistory', (table) => {
5
+ table.uuid('gameServerId').nullable().alter();
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('playerIpHistory', (table) => {
11
+ table.uuid('gameServerId').notNullable().alter();
12
+ });
13
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('playerInventory', (table) => {
5
+ table.index(['playerId', 'domain']);
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('playerInventory', (table) => {
11
+ table.dropIndex(['playerId', 'domain']);
12
+ });
13
+ }
@@ -0,0 +1,20 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.createTable('shopOrder', (table) => {
5
+ table.timestamps(true, true, true);
6
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
7
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
8
+ table.index('domain');
9
+
10
+ table.uuid('listingId').references('shopListing.id').onDelete('CASCADE').notNullable();
11
+ table.uuid('userId').references('users.id').onDelete('CASCADE').notNullable();
12
+
13
+ table.integer('amount').defaultTo(1).notNullable();
14
+ table.enum('status', ['COMPLETED', 'PAID', 'CANCELED']).notNullable();
15
+ });
16
+ }
17
+
18
+ export async function down(knex: Knex): Promise<void> {
19
+ await knex.schema.dropTable('shopOrder');
20
+ }
@@ -0,0 +1,31 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ // Find all variables where key starts with 'tp_'
5
+ const variables = await knex('variables').select().where('key', 'like', 'tp_%');
6
+
7
+ // Reduce the list to only public teleports
8
+ const publicTeleports = variables.filter((variable) => {
9
+ try {
10
+ const value = JSON.parse(variable.value);
11
+ return value.public;
12
+ } catch (error) {
13
+ // eslint-disable-next-line no-console
14
+ console.warn(`Error parsing JSON for variable ${variable.key}: ${error}. Skipping.`);
15
+ return false;
16
+ }
17
+ });
18
+
19
+ // Change the key for all public teleports from tp_xxx to pubtp_xxx
20
+ await Promise.all(
21
+ publicTeleports.map((teleport) => {
22
+ return knex('variables')
23
+ .update({ key: `pub${teleport.key}` })
24
+ .where('id', teleport.id);
25
+ }),
26
+ );
27
+ }
28
+
29
+ export async function down(_knex: Knex): Promise<void> {
30
+ // ... no down here, this is a one-way migration
31
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('events', (table) => {
5
+ table.index(['domain', 'eventName']);
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('events', (table) => {
11
+ table.dropIndex(['domain', 'eventName']);
12
+ });
13
+ }
@@ -0,0 +1,34 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.createTable('itemOnShopListing', (table) => {
5
+ table.timestamps(true, true, true);
6
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
7
+
8
+ table.uuid('listingId').references('shopListing.id').onDelete('CASCADE').notNullable();
9
+ table.uuid('itemId').references('items.id').onDelete('CASCADE');
10
+
11
+ table.integer('amount').defaultTo(1).notNullable();
12
+ // Amount must be positive and non-zero
13
+ table.check('"amount" > 0');
14
+
15
+ table.string('quality').nullable();
16
+ });
17
+
18
+ await knex.schema.alterTable('shopListing', (table) => {
19
+ table.dropChecks('"shopListing_check"');
20
+ table.dropColumn('functionId');
21
+ table.dropColumn('itemId');
22
+ });
23
+ }
24
+
25
+ export async function down(knex: Knex): Promise<void> {
26
+ await knex.schema.alterTable('shopListing', (table) => {
27
+ table.uuid('itemId').references('items.id').onDelete('CASCADE');
28
+ table.uuid('functionId').references('functions.id').onDelete('CASCADE');
29
+
30
+ table.check('("itemId" IS NOT NULL) OR ("functionId" IS NOT NULL)');
31
+ });
32
+
33
+ await knex.schema.dropTable('itemOnShopListing');
34
+ }
@@ -0,0 +1,9 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.table('permission').where('permission', 'READ_GAMESERVERS').delete();
5
+ }
6
+
7
+ export async function down(_knex: Knex): Promise<void> {
8
+ // No down migration...
9
+ }
@@ -0,0 +1,15 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('shopListing', (table) => {
5
+ table.timestamp('deletedAt').nullable();
6
+ table.boolean('draft').defaultTo(false);
7
+ });
8
+ }
9
+
10
+ export async function down(knex: Knex): Promise<void> {
11
+ await knex.schema.alterTable('shopListing', (table) => {
12
+ table.dropColumn('deletedAt');
13
+ table.dropColumn('draft');
14
+ });
15
+ }
@@ -0,0 +1,24 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('events', (table) => {
5
+ table.uuid('actingUserId').nullable();
6
+ table.foreign('actingUserId').references('id').inTable('users');
7
+
8
+ table.uuid('actingModuleId').nullable();
9
+ table.foreign('actingModuleId').references('id').inTable('modules');
10
+
11
+ table.index('actingUserId');
12
+ table.index('actingModuleId');
13
+ });
14
+ }
15
+
16
+ export async function down(knex: Knex): Promise<void> {
17
+ await knex.schema.alterTable('events', (table) => {
18
+ table.dropForeign(['actingUserId']);
19
+ table.dropColumn('actingUserId');
20
+
21
+ table.dropForeign(['actingModuleId']);
22
+ table.dropColumn('actingModuleId');
23
+ });
24
+ }
@@ -0,0 +1,16 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('domains', (table) => {
6
+ table.integer('rateLimitPoints').notNullable().defaultTo(2500);
7
+ table.integer('rateLimitDuration').notNullable().defaultTo(ms('15min'));
8
+ });
9
+ }
10
+
11
+ export async function down(knex: Knex): Promise<void> {
12
+ await knex.schema.alterTable('domains', (table) => {
13
+ table.dropColumn('rateLimitPoints');
14
+ table.dropColumn('rateLimitDuration');
15
+ });
16
+ }
@@ -0,0 +1,24 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('domains', (table) => {
6
+ table.text('externalReference').nullable();
7
+ });
8
+
9
+ // Select all domains with name starting cus_ and set externalReference to the name
10
+ const domains = await knex('domains').where('name', 'like', 'cus_%');
11
+ await Promise.all(
12
+ domains.map((domain) =>
13
+ knex('domains').where('id', domain.id).update({
14
+ externalReference: domain.name,
15
+ }),
16
+ ),
17
+ );
18
+ }
19
+
20
+ export async function down(knex: Knex): Promise<void> {
21
+ await knex.schema.alterTable('domains', (table) => {
22
+ table.dropColumn('externalReference');
23
+ });
24
+ }
@@ -0,0 +1,14 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('players', (table) => {
6
+ table.integer('steamLevel').nullable();
7
+ });
8
+ }
9
+
10
+ export async function down(knex: Knex): Promise<void> {
11
+ await knex.schema.alterTable('players', (table) => {
12
+ table.dropColumn('steamLevel');
13
+ });
14
+ }
@@ -0,0 +1,14 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('variables', (table) => {
6
+ table.timestamp('expiresAt').nullable();
7
+ });
8
+ }
9
+
10
+ export async function down(knex: Knex): Promise<void> {
11
+ await knex.schema.alterTable('variables', (table) => {
12
+ table.dropColumn('expiresAt');
13
+ });
14
+ }
@@ -0,0 +1,14 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('gameservers', (table) => {
6
+ table.boolean('enabled').defaultTo(true);
7
+ });
8
+ }
9
+
10
+ export async function down(knex: Knex): Promise<void> {
11
+ await knex.schema.alterTable('gameservers', (table) => {
12
+ table.dropColumn('enabled');
13
+ });
14
+ }
@@ -0,0 +1,12 @@
1
+ import ms from 'ms';
2
+ import { Knex } from 'knex';
3
+
4
+ export async function up(knex: Knex): Promise<void> {
5
+ await knex.schema.alterTable('domains', (table) => {
6
+ table.dropUnique(['name'], 'domains_name_unique');
7
+ });
8
+ }
9
+
10
+ export async function down(knex: Knex): Promise<void> {
11
+ // None, this is a one-way migration
12
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
5
+ table.integer('playtimeSeconds').defaultTo(0).notNullable();
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
11
+ table.dropColumn('playtimeSeconds');
12
+ });
13
+ }
@@ -0,0 +1,25 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.createTable('bans', (table) => {
5
+ table.timestamps(true, true, true);
6
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
7
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
8
+ table.index('domain');
9
+
10
+ table.uuid('gameServerId').references('gameservers.id').onDelete('CASCADE').notNullable();
11
+ table.uuid('playerId').references('players.id').onDelete('CASCADE').notNullable();
12
+ // PlayerId and gameServerId should be unique combined
13
+ table.unique(['playerId', 'gameServerId']);
14
+
15
+ table.boolean('takaroManaged').notNullable();
16
+ table.boolean('isGlobal').notNullable().defaultTo(false);
17
+
18
+ table.timestamp('until').nullable();
19
+ table.string('reason').nullable();
20
+ });
21
+ }
22
+
23
+ export async function down(knex: Knex): Promise<void> {
24
+ await knex.schema.dropTable('bans');
25
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('players', (table) => {
5
+ table.integer('playtimeSeconds').defaultTo(0).notNullable();
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('players', (table) => {
11
+ table.dropColumn('playtimeSeconds');
12
+ });
13
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('players', (table) => {
5
+ table.string('name').nullable().alter();
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('players', (table) => {
11
+ table.string('name').notNullable().alter();
12
+ });
13
+ }
@@ -0,0 +1,44 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('shopOrder', (table) => {
5
+ table.uuid('playerId').references('id').inTable('players');
6
+ });
7
+
8
+ // Migrate existing userId values to playerId by looking up the playerId from users
9
+ const shopOrders = await knex('shopOrder').select('id', 'userId');
10
+ for (const order of shopOrders) {
11
+ const user = await knex('users').where('id', order.userId).first();
12
+ if (user && user.playerId) {
13
+ await knex('shopOrder').where('id', order.id).update('playerId', user.playerId);
14
+ }
15
+ }
16
+
17
+ await knex.schema.alterTable('shopOrder', (table) => {
18
+ table.dropColumn('userId');
19
+ table.uuid('playerId').notNullable().alter();
20
+ table.index('playerId');
21
+ });
22
+ }
23
+
24
+ export async function down(knex: Knex): Promise<void> {
25
+ // Add userId column back to the shopOrder table
26
+ await knex.schema.alterTable('shopOrder', (table) => {
27
+ table.uuid('userId').references('id').inTable('users');
28
+ });
29
+
30
+ // Migrate playerId values back to userId by looking up the user from players
31
+ const shopOrders = await knex('shopOrder').select('id', 'playerId');
32
+ for (const order of shopOrders) {
33
+ const player = await knex('players').where('id', order.playerId).first();
34
+ if (player) {
35
+ await knex('shopOrder').where('id', order.id).update('userId', player.id);
36
+ }
37
+ }
38
+
39
+ // Drop playerId column
40
+ await knex.schema.alterTable('shopOrder', (table) => {
41
+ table.dropColumn('playerId');
42
+ table.uuid('userId').notNullable().alter();
43
+ });
44
+ }
@@ -0,0 +1,57 @@
1
+ import { Knex } from 'knex';
2
+
3
+ // This follows some research done with https://github.com/ankane/pghero
4
+
5
+ export async function up(knex: Knex): Promise<void> {
6
+ // Remove duplicate indexes
7
+ await knex.schema.alterTable('events', (table) => {
8
+ table.dropIndex('domain', 'events_domain_index');
9
+ });
10
+ await knex.schema.alterTable('items', (table) => {
11
+ table.dropIndex('code', 'items_code_index');
12
+ });
13
+ await knex.schema.alterTable('players', (table) => {
14
+ table.dropIndex('domain', 'players_domain_index');
15
+ });
16
+
17
+ // Add indexes
18
+ await knex.schema.alterTable('commands', (table) => {
19
+ table.index('moduleId');
20
+ });
21
+ await knex.schema.alterTable('events', (table) => {
22
+ table.index(['domain', 'createdAt']);
23
+ });
24
+ await knex.schema.alterTable('functions', (table) => {
25
+ table.index('moduleId');
26
+ });
27
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
28
+ table.index(['gameServerId', 'domain']);
29
+ });
30
+ }
31
+
32
+ export async function down(knex: Knex): Promise<void> {
33
+ // Re-add removed indexes (if needed)
34
+ await knex.schema.alterTable('events', (table) => {
35
+ table.index('domain', 'events_domain_index');
36
+ });
37
+ await knex.schema.alterTable('items', (table) => {
38
+ table.index('code', 'items_code_index');
39
+ });
40
+ await knex.schema.alterTable('players', (table) => {
41
+ table.index('domain', 'players_domain_index');
42
+ });
43
+
44
+ // Drop added indexes
45
+ await knex.schema.alterTable('commands', (table) => {
46
+ table.dropIndex('moduleId');
47
+ });
48
+ await knex.schema.alterTable('events', (table) => {
49
+ table.dropIndex(['domain', 'createdAt']);
50
+ });
51
+ await knex.schema.alterTable('functions', (table) => {
52
+ table.dropIndex('moduleId');
53
+ });
54
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
55
+ table.dropIndex(['gameServerId', 'domain']);
56
+ });
57
+ }
@@ -0,0 +1,16 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ // Set all listings w/o name to 'Unnamed'
5
+ await knex('shopListing').whereNull('name').update({ name: 'Unnamed' });
6
+
7
+ await knex.schema.alterTable('shopListing', (table) => {
8
+ table.string('name').notNullable().alter();
9
+ });
10
+ }
11
+
12
+ export async function down(knex: Knex): Promise<void> {
13
+ await knex.schema.alterTable('shopListing', (table) => {
14
+ table.string('name').nullable().alter();
15
+ });
16
+ }
@@ -0,0 +1,16 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ // When player, module, gameserver or userId is deleted, keep the event
5
+ await knex.schema.alterTable('events', (table) => {
6
+ table.dropForeign(['actingUserId']);
7
+ table.dropForeign(['actingModuleId']);
8
+ });
9
+ }
10
+
11
+ export async function down(knex: Knex): Promise<void> {
12
+ await knex.schema.alterTable('events', (table) => {
13
+ table.foreign('actingUserId').references('id').inTable('users').onDelete('CASCADE');
14
+ table.foreign('actingModuleId').references('id').inTable('modules').onDelete('CASCADE');
15
+ });
16
+ }
@@ -0,0 +1,31 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('permissionOnRole', (table) => {
5
+ table.index(['roleId']);
6
+ });
7
+
8
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
9
+ table.index(['domain', 'playerId']);
10
+ });
11
+
12
+ await knex.schema.alterTable('playerInventory', (table) => {
13
+ table.dropIndex(['playerId', 'domain']);
14
+ table.index(['playerId', 'domain', 'itemId']);
15
+ });
16
+ }
17
+
18
+ export async function down(knex: Knex): Promise<void> {
19
+ await knex.schema.alterTable('permissionOnRole', (table) => {
20
+ table.dropIndex(['roleId']);
21
+ });
22
+
23
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
24
+ table.dropIndex(['domain', 'playerId']);
25
+ });
26
+
27
+ await knex.schema.alterTable('playerInventory', (table) => {
28
+ table.dropIndex(['playerId', 'domain', 'itemId']);
29
+ table.index(['playerId', 'domain']);
30
+ });
31
+ }
@@ -0,0 +1,13 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ await knex.schema.alterTable('gameservers', (table) => {
5
+ table.timestamp('deletedAt').nullable().defaultTo(null);
6
+ });
7
+ }
8
+
9
+ export async function down(knex: Knex): Promise<void> {
10
+ await knex.schema.alterTable('gameservers', (table) => {
11
+ table.dropColumn('deletedAt');
12
+ });
13
+ }