@takaro/db 0.0.0-next.0da151e

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 (667) 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/util/alterEnum.d.ts +2 -0
  519. package/dist/migrations/util/alterEnum.d.ts.map +1 -0
  520. package/dist/migrations/util/alterEnum.js +8 -0
  521. package/dist/migrations/util/alterEnum.js.map +1 -0
  522. package/dist/queryBuilder.d.ts +43 -0
  523. package/dist/queryBuilder.d.ts.map +1 -0
  524. package/dist/queryBuilder.js +224 -0
  525. package/dist/queryBuilder.js.map +1 -0
  526. package/dist/redis.d.ts +21 -0
  527. package/dist/redis.d.ts.map +1 -0
  528. package/dist/redis.js +50 -0
  529. package/dist/redis.js.map +1 -0
  530. package/package.json +16 -0
  531. package/src/TakaroModel.ts +33 -0
  532. package/src/__tests__/encryption.integration.test.ts +57 -0
  533. package/src/__tests__/queryBuilder.integration.test.ts +208 -0
  534. package/src/config.ts +122 -0
  535. package/src/encryption.ts +26 -0
  536. package/src/errorTypeGuards.ts +11 -0
  537. package/src/knex.ts +59 -0
  538. package/src/main.ts +15 -0
  539. package/src/migrations/index.ts +70 -0
  540. package/src/migrations/sql/20220827191938_init.ts +183 -0
  541. package/src/migrations/sql/20221019173729_settings.ts +70 -0
  542. package/src/migrations/sql/20221029103554_refactor_function_assignments.ts +41 -0
  543. package/src/migrations/sql/20221102190532_commands.ts +66 -0
  544. package/src/migrations/sql/20221203135001-builtin_modules.ts +56 -0
  545. package/src/migrations/sql/20230308183400-persistent-variables.ts +74 -0
  546. package/src/migrations/sql/20230314183400-auth-ory.ts +27 -0
  547. package/src/migrations/sql/20230325156123_command-arguments.ts +24 -0
  548. package/src/migrations/sql/20230407132022-module-descriptions.ts +13 -0
  549. package/src/migrations/sql/20230407143733-module-json-schema-config.ts +16 -0
  550. package/src/migrations/sql/20230407173055-hook-regex-optional.ts +13 -0
  551. package/src/migrations/sql/20230415154935-cronjob-configs.ts +18 -0
  552. package/src/migrations/sql/20230503132906-variables-extra-meta.ts +31 -0
  553. package/src/migrations/sql/20230604130951-fix-hook-eventtypes.ts +12 -0
  554. package/src/migrations/sql/20230617081049-discordId-for-users.ts +16 -0
  555. package/src/migrations/sql/20230618053611-discord-funtionality.ts +34 -0
  556. package/src/migrations/sql/20230622192402-discord-hooks.ts +20 -0
  557. package/src/migrations/sql/20230707081218-playerOnGameServerExtension.ts +21 -0
  558. package/src/migrations/sql/20230710174340-events.ts +21 -0
  559. package/src/migrations/sql/20230712061220-roles-permissions-extension.ts +50 -0
  560. package/src/migrations/sql/20230713184927-variables-modulescoped.ts +32 -0
  561. package/src/migrations/sql/20230714045136-domain-index.ts +40 -0
  562. package/src/migrations/sql/20230714045727-events-index.ts +19 -0
  563. package/src/migrations/sql/20230715102519-module-permissions-extra-fields.ts +38 -0
  564. package/src/migrations/sql/20230724062109-roles-constraints.ts +16 -0
  565. package/src/migrations/sql/20230811095701-userId-on-events.ts +14 -0
  566. package/src/migrations/sql/20230921123717-count-for-permissions.ts +101 -0
  567. package/src/migrations/sql/20231111102812-details-system-permissions.ts +192 -0
  568. package/src/migrations/sql/20231114151343-system-roles.ts +46 -0
  569. package/src/migrations/sql/20231118082301-add-new-permissions.ts +200 -0
  570. package/src/migrations/sql/20231119115037-timedRoles.ts +23 -0
  571. package/src/migrations/sql/20231123150854-economy-base.ts +15 -0
  572. package/src/migrations/sql/20231123171611-economy-settings.ts +15 -0
  573. package/src/migrations/sql/20231124140441-json-module-assignments.ts +29 -0
  574. package/src/migrations/sql/20231208114507-settings-refactor.ts +114 -0
  575. package/src/migrations/sql/20231208171234-game-items.ts +20 -0
  576. package/src/migrations/sql/20231216100720-player-inventory.ts +16 -0
  577. package/src/migrations/sql/20231222180438-steam-data.ts +27 -0
  578. package/src/migrations/sql/20231223132631-pog-online.ts +13 -0
  579. package/src/migrations/sql/20231223212031-unique-index-item-def.ts +27 -0
  580. package/src/migrations/sql/20231224135126-gameserver-online-status.ts +13 -0
  581. package/src/migrations/sql/20231224155226-unique-pog.ts +27 -0
  582. package/src/migrations/sql/20231225140650-extra-ip-info.ts +27 -0
  583. package/src/migrations/sql/20231227144315-unique-constraints-player.ts +74 -0
  584. package/src/migrations/sql/20231229144707-more-player-constraints.ts +20 -0
  585. package/src/migrations/sql/20240101162751-add-settings-constraint.ts +39 -0
  586. package/src/migrations/sql/20240105130846-remove-some-module-perms.ts +104 -0
  587. package/src/migrations/sql/20240116141936-add-ui-schema-to-module.ts +13 -0
  588. package/src/migrations/sql/20240119152426-remove-hook-check.ts +18 -0
  589. package/src/migrations/sql/20240121142329-move-ip-history.ts +53 -0
  590. package/src/migrations/sql/20240202101208-rename-economy-to-economyUtils.ts +15 -0
  591. package/src/migrations/sql/20240216120143-domain-state.ts +13 -0
  592. package/src/migrations/sql/20240229141340-looser-fks-events.ts +20 -0
  593. package/src/migrations/sql/20240301063505-module-functions.ts +17 -0
  594. package/src/migrations/sql/20240613175009-lastseen-users-pog.ts +21 -0
  595. package/src/migrations/sql/20240614143517-shop.ts +39 -0
  596. package/src/migrations/sql/20240615145045-user-player-link.ts +20 -0
  597. package/src/migrations/sql/20240622132552-fix-ip-history-fk.ts +13 -0
  598. package/src/migrations/sql/20240626200803-player-inventory-idx.ts +13 -0
  599. package/src/migrations/sql/20240628174914-shop-orders.ts +20 -0
  600. package/src/migrations/sql/20240705140358-teleports-public-refactor.ts +31 -0
  601. package/src/migrations/sql/20240710181429-events-name-idx.ts +13 -0
  602. package/src/migrations/sql/20240711181423-shop-orders-multi-listing.ts +34 -0
  603. package/src/migrations/sql/20240718121004-delete-read-gameservers-perm.ts +9 -0
  604. package/src/migrations/sql/20240718150807-listing-deleted-and-draft-status.ts +15 -0
  605. package/src/migrations/sql/20240720135010-acting-user-and-module.ts +24 -0
  606. package/src/migrations/sql/20240811061243-domain-rate-limit-setting.ts +16 -0
  607. package/src/migrations/sql/20240814133931-domain-ext-ref.ts +24 -0
  608. package/src/migrations/sql/20240816171220-player-steam-level.ts +14 -0
  609. package/src/migrations/sql/20240830081157-variable-expiry.ts +14 -0
  610. package/src/migrations/sql/20240906125101-gameserver-enable.ts +14 -0
  611. package/src/migrations/sql/20240908185212-domain-name-not-unique.ts +12 -0
  612. package/src/migrations/sql/20240922110414-player-playtime.ts +13 -0
  613. package/src/migrations/sql/20240922133738-add-bans.ts +25 -0
  614. package/src/migrations/sql/20240929090313-global-playtime.ts +13 -0
  615. package/src/migrations/sql/20240929143849-player-name-null.ts +13 -0
  616. package/src/migrations/sql/20241012183754-shop-orders-belong-to-player.ts +44 -0
  617. package/src/migrations/sql/20241013173159-add-indexen-for-moduleId.ts +57 -0
  618. package/src/migrations/sql/20241020133133-make-listing-name-required.ts +16 -0
  619. package/src/migrations/sql/20241024164331-events-fk-fix.ts +16 -0
  620. package/src/migrations/sql/20241030130613-index-for-roleId.ts +31 -0
  621. package/src/migrations/sql/20241205201123-gameserver-deletedAt.ts +13 -0
  622. package/src/migrations/sql/20241330200212-module-versions.ts +384 -0
  623. package/src/migrations/sql/20250112102308-generic-gameserver.ts +55 -0
  624. package/src/migrations/sql/20250128200529-version-fixes.ts +13 -0
  625. package/src/migrations/sql/20250131183251-domain-settings.ts +55 -0
  626. package/src/migrations/sql/20250221130042-variable-length.ts +35 -0
  627. package/src/migrations/sql/20250221193144-versions-perf-improvements.ts +79 -0
  628. package/src/migrations/sql/20250223143705-fix-ban-constraint.ts +43 -0
  629. package/src/migrations/sql/20250305210650-more-module-metadata.ts +49 -0
  630. package/src/migrations/sql/20250307162855-default-systemconfig.ts +13 -0
  631. package/src/migrations/sql/20250312184104-unique-external-reference.ts +13 -0
  632. package/src/migrations/sql/20250314185501-root-users-not-dashboard-user.ts +17 -0
  633. package/src/migrations/sql/20250315191707-fix-constraint-module-items.ts +26 -0
  634. package/src/migrations/sql/20250519185149-add-item-indexes.ts +42 -0
  635. package/src/migrations/sql/20250524054924-tracking.ts +79 -0
  636. package/src/migrations/sql/20250525135204-ban-reason-length.ts +35 -0
  637. package/src/migrations/sql/20250605201140-shop-permissions-missing.ts +20 -0
  638. package/src/migrations/sql/20250606060546-inventory-tracking.ts +96 -0
  639. package/src/migrations/sql/20250613110835-add-platform-id-to-players.ts +51 -0
  640. package/src/migrations/sql/20250613203142-add-dimension-to-position.ts +25 -0
  641. package/src/migrations/sql/20250614113157-entities.ts +40 -0
  642. package/src/migrations/sql/20250629090822-player-query-performance-indices.ts +38 -0
  643. package/src/migrations/sql/20250701-command-query-performance-indices.ts +53 -0
  644. package/src/migrations/sql/20250702181214-platform-id-and-pog-indexes.ts +31 -0
  645. package/src/migrations/sql/20250703175326-add-ip-to-player-on-gameserver.ts +13 -0
  646. package/src/migrations/sql/20250707205720-items-permissions-missing.ts +20 -0
  647. package/src/migrations/sql/20250708095623-command-required-permissions.ts +13 -0
  648. package/src/migrations/sql/20250710131445-add-shop-categories.ts +98 -0
  649. package/src/migrations/sql/20250718-fix-player-inventory-history-pk.ts +161 -0
  650. package/src/migrations/sql/20250719160409-add-module-author-supportedgames.ts +31 -0
  651. package/src/migrations/sql/20250719175542-add-discord-permissions.ts +20 -0
  652. package/src/migrations/sql/20250726000000-discord-role-sync.ts +15 -0
  653. package/src/migrations/sql/20250727092719-add-quality-to-inventory.ts +13 -0
  654. package/src/migrations/sql/20250802124307-add-playeriphistory-composite-index.ts +13 -0
  655. package/src/migrations/sql/20250809122020-add-player-name-history.ts +31 -0
  656. package/src/migrations/sql/20250812163648-add-kpi-performance-indexes.ts +20 -0
  657. package/src/migrations/sql/20250814163747-shop-order-cascade-delete.ts +27 -0
  658. package/src/migrations/sql/20250815120000-optimize-shop-analytics-indexes.ts +46 -0
  659. package/src/migrations/sql/20251014120000-shop-order-auto-cancel-on-listing-delete.ts +75 -0
  660. package/src/migrations/sql/20251101000000-add-deleted-domain-state.ts +43 -0
  661. package/src/migrations/sql/20251108214824-unique-player-per-server.ts +30 -0
  662. package/src/migrations/util/alterEnum.ts +9 -0
  663. package/src/queryBuilder.ts +263 -0
  664. package/src/redis.ts +59 -0
  665. package/tsconfig.build.json +9 -0
  666. package/tsconfig.json +8 -0
  667. package/typedoc.json +3 -0
@@ -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
+ }
@@ -0,0 +1,384 @@
1
+ import { Knex } from 'knex';
2
+
3
+ export async function up(knex: Knex): Promise<void> {
4
+ // Create a new table for module versions
5
+ await knex.schema.createTable('moduleVersions', (table) => {
6
+ table.timestamps(true, true, true);
7
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
8
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
9
+ table.index('domain');
10
+ table.uuid('moduleId').notNullable().references('modules.id').onDelete('CASCADE');
11
+ table.string('tag').notNullable().defaultTo('0.0.1');
12
+ table.unique(['moduleId', 'tag']);
13
+
14
+ table.text('description').nullable();
15
+ table.text('configSchema').nullable();
16
+ table.text('uiSchema').nullable();
17
+ });
18
+
19
+ // Copy over all existing modules
20
+ const modules = await knex('modules').select('id', 'domain', 'description', 'configSchema', 'uiSchema');
21
+ console.log(`Migrating ${modules.length} modules to moduleVersions`);
22
+ for (const mod of modules) {
23
+ await knex('moduleVersions').insert({
24
+ domain: mod.domain,
25
+ moduleId: mod.id,
26
+ description: mod.description,
27
+ configSchema: mod.configSchema,
28
+ uiSchema: mod.uiSchema,
29
+ tag: 'latest',
30
+ });
31
+ }
32
+
33
+ // Delete the old columns
34
+ await knex.schema.table('modules', (table) => {
35
+ table.dropColumn('description');
36
+ table.dropColumn('configSchema');
37
+ table.dropColumn('uiSchema');
38
+ });
39
+
40
+ // Rename table moduleAssignments to moduleInstallations
41
+ await knex.schema.renameTable('moduleAssignments', 'moduleInstallations');
42
+
43
+ // Prepare versionId column in moduleInstallations
44
+ await knex.schema.table('moduleInstallations', (table) => {
45
+ table.uuid('versionId');
46
+ table.dropUnique(['gameserverId', 'moduleId', 'domain'], 'moduleassignments_gameserverid_moduleid_domain_unique');
47
+ });
48
+
49
+ // For each module installation, find the latest version and set it as the versionId
50
+ // There's a lot of installs, so we'll do this in batches
51
+ const batchSize = 100;
52
+ let offset = 0;
53
+ let installs;
54
+ do {
55
+ installs = await knex('moduleInstallations')
56
+ .select('id', 'moduleId')
57
+ .limit(batchSize)
58
+ .offset(offset)
59
+ .orderBy('createdAt');
60
+ for (const install of installs) {
61
+ const latestVersion = await knex('moduleVersions')
62
+ .select('id')
63
+ .where('moduleId', install.moduleId)
64
+ .orderBy('createdAt', 'desc')
65
+ .first();
66
+ await knex('moduleInstallations').where('id', install.id).update({ versionId: latestVersion.id });
67
+ }
68
+ offset += batchSize;
69
+ } while (installs.length === batchSize);
70
+
71
+ await knex('moduleInstallations').whereNull('versionId').delete();
72
+
73
+ // Set versionId as not nullable and add foreign key constraint
74
+ await knex.schema.alterTable('moduleInstallations', (table) => {
75
+ table.uuid('versionId').notNullable().alter();
76
+ table.foreign('versionId').references('moduleVersions.id').onDelete('CASCADE');
77
+ });
78
+
79
+ // Now, we also need to move the commands,hooks and cronjobs to the moduleVersions table
80
+ // Currently, they have an FK to modules, but we need to replace them with moduleVersions
81
+ // Same logic here, let's just link all of them to the latest version of the module (which is the only one that should exist)
82
+
83
+ // First, let's remove the old FKs
84
+ // And add a new column for the versionId
85
+ await knex.schema.alterTable('commands', (table) => {
86
+ table.dropForeign('moduleId');
87
+ table.uuid('versionId');
88
+ });
89
+
90
+ await knex.schema.alterTable('hooks', (table) => {
91
+ table.dropForeign('moduleId');
92
+ table.uuid('versionId');
93
+ });
94
+
95
+ await knex.schema.alterTable('cronJobs', (table) => {
96
+ table.dropForeign('moduleId');
97
+ table.uuid('versionId');
98
+ });
99
+
100
+ await knex.schema.alterTable('permission', (table) => {
101
+ table.dropForeign('moduleId', 'modulepermission_moduleid_foreign');
102
+ table.uuid('moduleVersionId');
103
+ });
104
+
105
+ await knex.schema.alterTable('functions', (table) => {
106
+ table.dropForeign('moduleId');
107
+ table.uuid('versionId');
108
+ });
109
+
110
+ offset = 0;
111
+ let commands;
112
+ do {
113
+ commands = await knex('commands').select('id', 'moduleId').limit(batchSize).offset(offset).orderBy('createdAt');
114
+ for (const command of commands) {
115
+ const latestVersion = await knex('moduleVersions')
116
+ .select('id')
117
+ .where('moduleId', command.moduleId)
118
+ .orderBy('createdAt', 'desc')
119
+ .first();
120
+ await knex('commands').where('id', command.id).update({ versionId: latestVersion.id });
121
+ }
122
+ offset += batchSize;
123
+ } while (commands.length === batchSize);
124
+
125
+ offset = 0;
126
+ let hooks;
127
+ do {
128
+ hooks = await knex('hooks').select('id', 'moduleId').limit(batchSize).offset(offset).orderBy('createdAt');
129
+ for (const hook of hooks) {
130
+ const latestVersion = await knex('moduleVersions')
131
+ .select('id')
132
+ .where('moduleId', hook.moduleId)
133
+ .orderBy('createdAt', 'desc')
134
+ .first();
135
+ await knex('hooks').where('id', hook.id).update({ versionId: latestVersion.id });
136
+ }
137
+ offset += batchSize;
138
+ } while (hooks.length === batchSize);
139
+
140
+ offset = 0;
141
+ let cronjobs;
142
+ do {
143
+ cronjobs = await knex('cronJobs').select('id', 'moduleId').limit(batchSize).offset(offset).orderBy('createdAt');
144
+ for (const cronjob of cronjobs) {
145
+ const latestVersion = await knex('moduleVersions')
146
+ .select('id')
147
+ .where('moduleId', cronjob.moduleId)
148
+ .orderBy('createdAt', 'desc')
149
+ .first();
150
+ await knex('cronJobs').where('id', cronjob.id).update({ versionId: latestVersion.id });
151
+ }
152
+ offset += batchSize;
153
+ } while (cronjobs.length === batchSize);
154
+
155
+ offset = 0;
156
+ let permissions;
157
+ do {
158
+ permissions = await knex('permission')
159
+ .select('id', 'moduleId')
160
+ .limit(batchSize)
161
+ .offset(offset)
162
+ .orderBy('createdAt');
163
+ for (const permission of permissions) {
164
+ if (!permission.moduleId) {
165
+ // Not a module scoped permission, so skip
166
+ continue;
167
+ }
168
+ const latestVersion = await knex('moduleVersions')
169
+ .select('id')
170
+ .where('moduleId', permission.moduleId)
171
+ .orderBy('createdAt', 'desc')
172
+ .first();
173
+ await knex('permission').where('id', permission.id).update({ moduleVersionId: latestVersion.id });
174
+ }
175
+ offset += batchSize;
176
+ } while (permissions.length === batchSize);
177
+
178
+ offset = 0;
179
+ let functions;
180
+ do {
181
+ functions = await knex('functions').select('id', 'moduleId').limit(batchSize).offset(offset).orderBy('createdAt');
182
+ for (const func of functions) {
183
+ if (!func.moduleId) {
184
+ // Not module scoped, so skip
185
+ continue;
186
+ }
187
+ const latestVersion = await knex('moduleVersions')
188
+ .select('id')
189
+ .where('moduleId', func.moduleId)
190
+ .orderBy('createdAt', 'desc')
191
+ .first();
192
+ await knex('functions').where('id', func.id).update({ versionId: latestVersion.id });
193
+ }
194
+ offset += batchSize;
195
+ } while (functions.length === batchSize);
196
+
197
+ // Finally, let's drop old columns and ensure new FK is in place
198
+ const orphanedCommands = await knex('commands').delete().whereNull('versionId');
199
+ console.log(`Deleted ${orphanedCommands} orphaned commands`);
200
+ const orphanedHooks = await knex('hooks').delete().whereNull('versionId');
201
+ console.log(`Deleted ${orphanedHooks} orphaned hooks`);
202
+ const orphanedCronjobs = await knex('cronJobs').delete().whereNull('versionId');
203
+ console.log(`Deleted ${orphanedCronjobs} orphaned cronjobs`);
204
+
205
+ await knex.schema.alterTable('commands', (table) => {
206
+ table.dropColumn('moduleId');
207
+ table.uuid('versionId').notNullable().alter();
208
+ table.foreign('versionId').references('moduleVersions.id').onDelete('CASCADE');
209
+ });
210
+
211
+ await knex.schema.alterTable('hooks', (table) => {
212
+ table.dropColumn('moduleId');
213
+ table.uuid('versionId').notNullable().alter();
214
+ table.foreign('versionId').references('moduleVersions.id').onDelete('CASCADE');
215
+ });
216
+
217
+ await knex.schema.alterTable('cronJobs', (table) => {
218
+ table.dropColumn('moduleId');
219
+ table.uuid('versionId').notNullable().alter();
220
+ table.foreign('versionId').references('moduleVersions.id').onDelete('CASCADE');
221
+ });
222
+
223
+ await knex.schema.alterTable('permission', (table) => {
224
+ table.dropColumn('moduleId');
225
+ table.uuid('moduleVersionId').nullable().alter();
226
+ table.foreign('moduleVersionId').references('moduleVersions.id').onDelete('CASCADE');
227
+ });
228
+
229
+ await knex.schema.alterTable('functions', (table) => {
230
+ table.dropColumn('moduleId');
231
+ table.uuid('versionId').nullable().alter();
232
+ table.foreign('versionId').references('moduleVersions.id').onDelete('CASCADE');
233
+ });
234
+
235
+ await knex.schema.alterTable('moduleInstallations', (table) => {
236
+ table.unique(['moduleId', 'gameserverId', 'domain'], { indexName: 'unique_module_per_gameserver' });
237
+ table.index(['moduleId', 'gameserverId', 'domain'], 'idx_moduleinstallations_module_gameserver');
238
+ });
239
+
240
+ // Hook name must be unique inside a version
241
+ await knex.schema.alterTable('hooks', (table) => {
242
+ table.unique(['name', 'versionId']);
243
+ });
244
+ }
245
+
246
+ export async function down(knex: Knex): Promise<void> {
247
+ await knex.schema.alterTable('hooks', (table) => {
248
+ table.dropUnique(['name', 'versionId']);
249
+ });
250
+
251
+ await knex.schema.alterTable('moduleInstallations', (table) => {
252
+ table.dropUnique(['moduleId', 'gameserverId', 'domain'], 'unique_module_per_gameserver');
253
+ table.dropIndex(['moduleId', 'gameserverId', 'domain'], 'idx_moduleinstallations_module_gameserver');
254
+ });
255
+
256
+ // Remove the FKs from commands, hooks and cronjobs
257
+ await knex.schema.alterTable('commands', (table) => {
258
+ table.dropForeign('versionId');
259
+ });
260
+
261
+ await knex.schema.alterTable('hooks', (table) => {
262
+ table.dropForeign('versionId');
263
+ });
264
+
265
+ await knex.schema.alterTable('cronJobs', (table) => {
266
+ table.dropForeign('versionId');
267
+ });
268
+
269
+ await knex.schema.alterTable('permission', (table) => {
270
+ table.dropForeign('moduleVersionId');
271
+ });
272
+
273
+ await knex.schema.alterTable('functions', (table) => {
274
+ table.dropForeign('versionId');
275
+ });
276
+
277
+ // Drop the new columns
278
+ await knex.schema.alterTable('moduleInstallations', (table) => {
279
+ table.dropForeign('versionId');
280
+ table.dropColumn('versionId');
281
+ table.unique(['gameserverId', 'moduleId', 'domain'], {
282
+ indexName: 'moduleassignments_gameserverid_moduleid_domain_unique',
283
+ });
284
+ });
285
+
286
+ // Rename table moduleInstallations to moduleAssignments
287
+ await knex.schema.renameTable('moduleInstallations', 'moduleAssignments');
288
+
289
+ // Add back the old columns
290
+ await knex.schema.table('modules', (table) => {
291
+ table.text('description').nullable();
292
+ table.text('configSchema').nullable();
293
+ table.text('uiSchema').nullable();
294
+ });
295
+
296
+ // Add the old column back
297
+ await knex.schema.alterTable('commands', (table) => {
298
+ table.uuid('moduleId');
299
+ });
300
+
301
+ await knex.schema.alterTable('hooks', (table) => {
302
+ table.uuid('moduleId');
303
+ });
304
+
305
+ await knex.schema.alterTable('cronJobs', (table) => {
306
+ table.uuid('moduleId');
307
+ });
308
+
309
+ await knex.schema.alterTable('permission', (table) => {
310
+ table.uuid('moduleId').nullable();
311
+ });
312
+
313
+ await knex.schema.alterTable('functions', (table) => {
314
+ table.uuid('moduleId').nullable();
315
+ });
316
+
317
+ // Copy over the latest version of each module
318
+ const versions = await knex('moduleVersions')
319
+ .select('id', 'moduleId', 'createdAt', 'description', 'configSchema', 'uiSchema')
320
+ .distinct('moduleId')
321
+ .orderBy('createdAt', 'desc');
322
+ for (const version of versions) {
323
+ await knex('modules').where('id', version.moduleId).update({
324
+ description: version.description,
325
+ configSchema: version.configSchema,
326
+ uiSchema: version.uiSchema,
327
+ });
328
+
329
+ // Copy over the commands, hooks, cronjobs and permissions
330
+ const commands = await knex('commands').select('id').where('versionId', version.id);
331
+ for (const command of commands) {
332
+ await knex('commands').where('id', command.id).update({ moduleId: version.moduleId });
333
+ }
334
+
335
+ const hooks = await knex('hooks').select('id').where('versionId', version.id);
336
+ for (const hook of hooks) {
337
+ await knex('hooks').where('id', hook.id).update({ moduleId: version.moduleId });
338
+ }
339
+
340
+ const cronjobs = await knex('cronJobs').select('id').where('versionId', version.id);
341
+ for (const cronjob of cronjobs) {
342
+ await knex('cronJobs').where('id', cronjob.id).update({ moduleId: version.moduleId });
343
+ }
344
+
345
+ const permissions = await knex('permission').select('id').where('moduleVersionId', version.id);
346
+ for (const permission of permissions) {
347
+ await knex('permission').where('id', permission.id).update({ moduleId: version.moduleId });
348
+ }
349
+
350
+ const functions = await knex('functions').select('id').where('versionId', version.id);
351
+ for (const func of functions) {
352
+ await knex('functions').where('id', func.id).update({ moduleId: version.moduleId });
353
+ }
354
+ }
355
+
356
+ // Enable the old FKs
357
+ await knex.schema.alterTable('commands', (table) => {
358
+ table.foreign('moduleId').references('modules.id').onDelete('CASCADE');
359
+ table.dropColumn('versionId');
360
+ });
361
+
362
+ await knex.schema.alterTable('hooks', (table) => {
363
+ table.foreign('moduleId').references('modules.id').onDelete('CASCADE');
364
+ table.dropColumn('versionId');
365
+ });
366
+
367
+ await knex.schema.alterTable('cronJobs', (table) => {
368
+ table.foreign('moduleId').references('modules.id').onDelete('CASCADE');
369
+ table.dropColumn('versionId');
370
+ });
371
+
372
+ await knex.schema.alterTable('permission', (table) => {
373
+ table.foreign('moduleId', 'modulepermission_moduleid_foreign').references('modules.id').onDelete('CASCADE');
374
+ table.dropColumn('moduleVersionId');
375
+ });
376
+
377
+ await knex.schema.alterTable('functions', (table) => {
378
+ table.foreign('moduleId').references('modules.id').onDelete('CASCADE');
379
+ table.dropColumn('versionId');
380
+ });
381
+
382
+ // Drop the moduleVersions table
383
+ await knex.schema.dropTable('moduleVersions');
384
+ }