@takaro/db 0.0.1

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 (263) hide show
  1. package/README.md +1 -0
  2. package/dist/TakaroModel.d.ts +15 -0
  3. package/dist/TakaroModel.js +23 -0
  4. package/dist/TakaroModel.js.map +1 -0
  5. package/dist/config.d.ts +98 -0
  6. package/dist/config.js +81 -0
  7. package/dist/config.js.map +1 -0
  8. package/dist/encryption.d.ts +4 -0
  9. package/dist/encryption.js +24 -0
  10. package/dist/encryption.js.map +1 -0
  11. package/dist/errorTypeGuards.d.ts +2 -0
  12. package/dist/errorTypeGuards.js +11 -0
  13. package/dist/errorTypeGuards.js.map +1 -0
  14. package/dist/knex.d.ts +16 -0
  15. package/dist/knex.js +46 -0
  16. package/dist/knex.js.map +1 -0
  17. package/dist/main.d.ts +8 -0
  18. package/dist/main.js +9 -0
  19. package/dist/main.js.map +1 -0
  20. package/dist/migrations/index.d.ts +2 -0
  21. package/dist/migrations/index.js +59 -0
  22. package/dist/migrations/index.js.map +1 -0
  23. package/dist/migrations/sql/20220827191938_init.d.ts +3 -0
  24. package/dist/migrations/sql/20220827191938_init.js +155 -0
  25. package/dist/migrations/sql/20220827191938_init.js.map +1 -0
  26. package/dist/migrations/sql/20221019173729_settings.d.ts +3 -0
  27. package/dist/migrations/sql/20221019173729_settings.js +61 -0
  28. package/dist/migrations/sql/20221019173729_settings.js.map +1 -0
  29. package/dist/migrations/sql/20221029103554_refactor_function_assignments.d.ts +3 -0
  30. package/dist/migrations/sql/20221029103554_refactor_function_assignments.js +33 -0
  31. package/dist/migrations/sql/20221029103554_refactor_function_assignments.js.map +1 -0
  32. package/dist/migrations/sql/20221102190532_commands.d.ts +3 -0
  33. package/dist/migrations/sql/20221102190532_commands.js +58 -0
  34. package/dist/migrations/sql/20221102190532_commands.js.map +1 -0
  35. package/dist/migrations/sql/20221203135001-builtin_modules.d.ts +3 -0
  36. package/dist/migrations/sql/20221203135001-builtin_modules.js +44 -0
  37. package/dist/migrations/sql/20221203135001-builtin_modules.js.map +1 -0
  38. package/dist/migrations/sql/20230308183400-persistent-variables.d.ts +3 -0
  39. package/dist/migrations/sql/20230308183400-persistent-variables.js +63 -0
  40. package/dist/migrations/sql/20230308183400-persistent-variables.js.map +1 -0
  41. package/dist/migrations/sql/20230314183400-auth-ory.d.ts +3 -0
  42. package/dist/migrations/sql/20230314183400-auth-ory.js +23 -0
  43. package/dist/migrations/sql/20230314183400-auth-ory.js.map +1 -0
  44. package/dist/migrations/sql/20230325156123_command-arguments.d.ts +3 -0
  45. package/dist/migrations/sql/20230325156123_command-arguments.js +19 -0
  46. package/dist/migrations/sql/20230325156123_command-arguments.js.map +1 -0
  47. package/dist/migrations/sql/20230407132022-module-descriptions.d.ts +3 -0
  48. package/dist/migrations/sql/20230407132022-module-descriptions.js +11 -0
  49. package/dist/migrations/sql/20230407132022-module-descriptions.js.map +1 -0
  50. package/dist/migrations/sql/20230407143733-module-json-schema-config.d.ts +3 -0
  51. package/dist/migrations/sql/20230407143733-module-json-schema-config.js +14 -0
  52. package/dist/migrations/sql/20230407143733-module-json-schema-config.js.map +1 -0
  53. package/dist/migrations/sql/20230407173055-hook-regex-optional.d.ts +3 -0
  54. package/dist/migrations/sql/20230407173055-hook-regex-optional.js +11 -0
  55. package/dist/migrations/sql/20230407173055-hook-regex-optional.js.map +1 -0
  56. package/dist/migrations/sql/20230415154935-cronjob-configs.d.ts +3 -0
  57. package/dist/migrations/sql/20230415154935-cronjob-configs.js +16 -0
  58. package/dist/migrations/sql/20230415154935-cronjob-configs.js.map +1 -0
  59. package/dist/migrations/sql/20230503132906-variables-extra-meta.d.ts +3 -0
  60. package/dist/migrations/sql/20230503132906-variables-extra-meta.js +26 -0
  61. package/dist/migrations/sql/20230503132906-variables-extra-meta.js.map +1 -0
  62. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.d.ts +3 -0
  63. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js +8 -0
  64. package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js.map +1 -0
  65. package/dist/migrations/sql/20230617081049-discordId-for-users.d.ts +3 -0
  66. package/dist/migrations/sql/20230617081049-discordId-for-users.js +14 -0
  67. package/dist/migrations/sql/20230617081049-discordId-for-users.js.map +1 -0
  68. package/dist/migrations/sql/20230618053611-discord-funtionality.d.ts +3 -0
  69. package/dist/migrations/sql/20230618053611-discord-funtionality.js +26 -0
  70. package/dist/migrations/sql/20230618053611-discord-funtionality.js.map +1 -0
  71. package/dist/migrations/sql/20230622192402-discord-hooks.d.ts +3 -0
  72. package/dist/migrations/sql/20230622192402-discord-hooks.js +14 -0
  73. package/dist/migrations/sql/20230622192402-discord-hooks.js.map +1 -0
  74. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.d.ts +3 -0
  75. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js +19 -0
  76. package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js.map +1 -0
  77. package/dist/migrations/sql/20230710174340-events.d.ts +3 -0
  78. package/dist/migrations/sql/20230710174340-events.js +16 -0
  79. package/dist/migrations/sql/20230710174340-events.js.map +1 -0
  80. package/dist/migrations/sql/20230712061220-roles-permissions-extension.d.ts +3 -0
  81. package/dist/migrations/sql/20230712061220-roles-permissions-extension.js +43 -0
  82. package/dist/migrations/sql/20230712061220-roles-permissions-extension.js.map +1 -0
  83. package/dist/migrations/sql/20230713184927-variables-modulescoped.d.ts +3 -0
  84. package/dist/migrations/sql/20230713184927-variables-modulescoped.js +27 -0
  85. package/dist/migrations/sql/20230713184927-variables-modulescoped.js.map +1 -0
  86. package/dist/migrations/sql/20230714045136-domain-index.d.ts +3 -0
  87. package/dist/migrations/sql/20230714045136-domain-index.js +37 -0
  88. package/dist/migrations/sql/20230714045136-domain-index.js.map +1 -0
  89. package/dist/migrations/sql/20230714045727-events-index.d.ts +3 -0
  90. package/dist/migrations/sql/20230714045727-events-index.js +17 -0
  91. package/dist/migrations/sql/20230714045727-events-index.js.map +1 -0
  92. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.d.ts +3 -0
  93. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js +32 -0
  94. package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js.map +1 -0
  95. package/dist/migrations/sql/20230724062109-roles-constraints.d.ts +3 -0
  96. package/dist/migrations/sql/20230724062109-roles-constraints.js +14 -0
  97. package/dist/migrations/sql/20230724062109-roles-constraints.js.map +1 -0
  98. package/dist/migrations/sql/20230811095701-userId-on-events.d.ts +3 -0
  99. package/dist/migrations/sql/20230811095701-userId-on-events.js +12 -0
  100. package/dist/migrations/sql/20230811095701-userId-on-events.js.map +1 -0
  101. package/dist/migrations/sql/20230921123717-count-for-permissions.d.ts +3 -0
  102. package/dist/migrations/sql/20230921123717-count-for-permissions.js +84 -0
  103. package/dist/migrations/sql/20230921123717-count-for-permissions.js.map +1 -0
  104. package/dist/migrations/sql/20231111102812-details-system-permissions.d.ts +36 -0
  105. package/dist/migrations/sql/20231111102812-details-system-permissions.js +179 -0
  106. package/dist/migrations/sql/20231111102812-details-system-permissions.js.map +1 -0
  107. package/dist/migrations/sql/20231114151343-system-roles.d.ts +3 -0
  108. package/dist/migrations/sql/20231114151343-system-roles.js +41 -0
  109. package/dist/migrations/sql/20231114151343-system-roles.js.map +1 -0
  110. package/dist/migrations/sql/20231118082301-add-new-permissions.d.ts +36 -0
  111. package/dist/migrations/sql/20231118082301-add-new-permissions.js +186 -0
  112. package/dist/migrations/sql/20231118082301-add-new-permissions.js.map +1 -0
  113. package/dist/migrations/sql/20231119115037-timedRoles.d.ts +3 -0
  114. package/dist/migrations/sql/20231119115037-timedRoles.js +19 -0
  115. package/dist/migrations/sql/20231119115037-timedRoles.js.map +1 -0
  116. package/dist/migrations/sql/20231123150854-economy-base.d.ts +3 -0
  117. package/dist/migrations/sql/20231123150854-economy-base.js +13 -0
  118. package/dist/migrations/sql/20231123150854-economy-base.js.map +1 -0
  119. package/dist/migrations/sql/20231123171611-economy-settings.d.ts +3 -0
  120. package/dist/migrations/sql/20231123171611-economy-settings.js +13 -0
  121. package/dist/migrations/sql/20231123171611-economy-settings.js.map +1 -0
  122. package/dist/migrations/sql/20231124140441-json-module-assignments.d.ts +3 -0
  123. package/dist/migrations/sql/20231124140441-json-module-assignments.js +25 -0
  124. package/dist/migrations/sql/20231124140441-json-module-assignments.js.map +1 -0
  125. package/dist/migrations/sql/20231208114507-settings-refactor.d.ts +3 -0
  126. package/dist/migrations/sql/20231208114507-settings-refactor.js +95 -0
  127. package/dist/migrations/sql/20231208114507-settings-refactor.js.map +1 -0
  128. package/dist/migrations/sql/20231208171234-game-items.d.ts +3 -0
  129. package/dist/migrations/sql/20231208171234-game-items.js +18 -0
  130. package/dist/migrations/sql/20231208171234-game-items.js.map +1 -0
  131. package/dist/migrations/sql/20231216100720-player-inventory.d.ts +3 -0
  132. package/dist/migrations/sql/20231216100720-player-inventory.js +14 -0
  133. package/dist/migrations/sql/20231216100720-player-inventory.js.map +1 -0
  134. package/dist/migrations/sql/20231222180438-steam-data.d.ts +3 -0
  135. package/dist/migrations/sql/20231222180438-steam-data.js +25 -0
  136. package/dist/migrations/sql/20231222180438-steam-data.js.map +1 -0
  137. package/dist/migrations/sql/20231223132631-pog-online.d.ts +3 -0
  138. package/dist/migrations/sql/20231223132631-pog-online.js +11 -0
  139. package/dist/migrations/sql/20231223132631-pog-online.js.map +1 -0
  140. package/dist/migrations/sql/20231223212031-unique-index-item-def.d.ts +3 -0
  141. package/dist/migrations/sql/20231223212031-unique-index-item-def.js +24 -0
  142. package/dist/migrations/sql/20231223212031-unique-index-item-def.js.map +1 -0
  143. package/dist/migrations/sql/20231224135126-gameserver-online-status.d.ts +3 -0
  144. package/dist/migrations/sql/20231224135126-gameserver-online-status.js +11 -0
  145. package/dist/migrations/sql/20231224135126-gameserver-online-status.js.map +1 -0
  146. package/dist/migrations/sql/20231224155226-unique-pog.d.ts +3 -0
  147. package/dist/migrations/sql/20231224155226-unique-pog.js +24 -0
  148. package/dist/migrations/sql/20231224155226-unique-pog.js.map +1 -0
  149. package/dist/migrations/sql/20231225140650-extra-ip-info.d.ts +3 -0
  150. package/dist/migrations/sql/20231225140650-extra-ip-info.js +23 -0
  151. package/dist/migrations/sql/20231225140650-extra-ip-info.js.map +1 -0
  152. package/dist/migrations/sql/20231227144315-unique-constraints-player.d.ts +3 -0
  153. package/dist/migrations/sql/20231227144315-unique-constraints-player.js +67 -0
  154. package/dist/migrations/sql/20231227144315-unique-constraints-player.js.map +1 -0
  155. package/dist/migrations/sql/20231229144707-more-player-constraints.d.ts +3 -0
  156. package/dist/migrations/sql/20231229144707-more-player-constraints.js +17 -0
  157. package/dist/migrations/sql/20231229144707-more-player-constraints.js.map +1 -0
  158. package/dist/migrations/sql/20240101162751-add-settings-constraint.d.ts +3 -0
  159. package/dist/migrations/sql/20240101162751-add-settings-constraint.js +34 -0
  160. package/dist/migrations/sql/20240101162751-add-settings-constraint.js.map +1 -0
  161. package/dist/migrations/sql/20240105130846-remove-some-module-perms.d.ts +3 -0
  162. package/dist/migrations/sql/20240105130846-remove-some-module-perms.js +80 -0
  163. package/dist/migrations/sql/20240105130846-remove-some-module-perms.js.map +1 -0
  164. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.d.ts +3 -0
  165. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js +11 -0
  166. package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js.map +1 -0
  167. package/dist/migrations/sql/20240119152426-remove-hook-check.d.ts +3 -0
  168. package/dist/migrations/sql/20240119152426-remove-hook-check.js +14 -0
  169. package/dist/migrations/sql/20240119152426-remove-hook-check.js.map +1 -0
  170. package/dist/migrations/sql/20240121142329-move-ip-history.d.ts +3 -0
  171. package/dist/migrations/sql/20240121142329-move-ip-history.js +44 -0
  172. package/dist/migrations/sql/20240121142329-move-ip-history.js.map +1 -0
  173. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.d.ts +3 -0
  174. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js +13 -0
  175. package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js.map +1 -0
  176. package/dist/migrations/sql/20240216120143-domain-state.d.ts +3 -0
  177. package/dist/migrations/sql/20240216120143-domain-state.js +11 -0
  178. package/dist/migrations/sql/20240216120143-domain-state.js.map +1 -0
  179. package/dist/migrations/sql/20240229141340-looser-fks-events.d.ts +3 -0
  180. package/dist/migrations/sql/20240229141340-looser-fks-events.js +18 -0
  181. package/dist/migrations/sql/20240229141340-looser-fks-events.js.map +1 -0
  182. package/dist/migrations/sql/20240301063505-module-functions.d.ts +3 -0
  183. package/dist/migrations/sql/20240301063505-module-functions.js +14 -0
  184. package/dist/migrations/sql/20240301063505-module-functions.js.map +1 -0
  185. package/dist/migrations/util/alterEnum.d.ts +1 -0
  186. package/dist/migrations/util/alterEnum.js +9 -0
  187. package/dist/migrations/util/alterEnum.js.map +1 -0
  188. package/dist/queryBuilder.d.ts +28 -0
  189. package/dist/queryBuilder.js +132 -0
  190. package/dist/queryBuilder.js.map +1 -0
  191. package/dist/redis.d.ts +20 -0
  192. package/dist/redis.js +49 -0
  193. package/dist/redis.js.map +1 -0
  194. package/package.json +29 -0
  195. package/src/TakaroModel.ts +32 -0
  196. package/src/__tests__/encryption.integration.test.ts +56 -0
  197. package/src/__tests__/queryBuilder.integration.test.ts +202 -0
  198. package/src/config.ts +101 -0
  199. package/src/encryption.ts +27 -0
  200. package/src/errorTypeGuards.ts +11 -0
  201. package/src/knex.ts +54 -0
  202. package/src/main.ts +15 -0
  203. package/src/migrations/index.ts +70 -0
  204. package/src/migrations/sql/20220827191938_init.ts +183 -0
  205. package/src/migrations/sql/20221019173729_settings.ts +70 -0
  206. package/src/migrations/sql/20221029103554_refactor_function_assignments.ts +41 -0
  207. package/src/migrations/sql/20221102190532_commands.ts +66 -0
  208. package/src/migrations/sql/20221203135001-builtin_modules.ts +56 -0
  209. package/src/migrations/sql/20230308183400-persistent-variables.ts +74 -0
  210. package/src/migrations/sql/20230314183400-auth-ory.ts +27 -0
  211. package/src/migrations/sql/20230325156123_command-arguments.ts +24 -0
  212. package/src/migrations/sql/20230407132022-module-descriptions.ts +13 -0
  213. package/src/migrations/sql/20230407143733-module-json-schema-config.ts +16 -0
  214. package/src/migrations/sql/20230407173055-hook-regex-optional.ts +13 -0
  215. package/src/migrations/sql/20230415154935-cronjob-configs.ts +18 -0
  216. package/src/migrations/sql/20230503132906-variables-extra-meta.ts +31 -0
  217. package/src/migrations/sql/20230604130951-fix-hook-eventtypes.ts +12 -0
  218. package/src/migrations/sql/20230617081049-discordId-for-users.ts +16 -0
  219. package/src/migrations/sql/20230618053611-discord-funtionality.ts +34 -0
  220. package/src/migrations/sql/20230622192402-discord-hooks.ts +20 -0
  221. package/src/migrations/sql/20230707081218-playerOnGameServerExtension.ts +21 -0
  222. package/src/migrations/sql/20230710174340-events.ts +21 -0
  223. package/src/migrations/sql/20230712061220-roles-permissions-extension.ts +50 -0
  224. package/src/migrations/sql/20230713184927-variables-modulescoped.ts +32 -0
  225. package/src/migrations/sql/20230714045136-domain-index.ts +40 -0
  226. package/src/migrations/sql/20230714045727-events-index.ts +19 -0
  227. package/src/migrations/sql/20230715102519-module-permissions-extra-fields.ts +38 -0
  228. package/src/migrations/sql/20230724062109-roles-constraints.ts +16 -0
  229. package/src/migrations/sql/20230811095701-userId-on-events.ts +14 -0
  230. package/src/migrations/sql/20230921123717-count-for-permissions.ts +101 -0
  231. package/src/migrations/sql/20231111102812-details-system-permissions.ts +192 -0
  232. package/src/migrations/sql/20231114151343-system-roles.ts +46 -0
  233. package/src/migrations/sql/20231118082301-add-new-permissions.ts +200 -0
  234. package/src/migrations/sql/20231119115037-timedRoles.ts +23 -0
  235. package/src/migrations/sql/20231123150854-economy-base.ts +15 -0
  236. package/src/migrations/sql/20231123171611-economy-settings.ts +15 -0
  237. package/src/migrations/sql/20231124140441-json-module-assignments.ts +29 -0
  238. package/src/migrations/sql/20231208114507-settings-refactor.ts +114 -0
  239. package/src/migrations/sql/20231208171234-game-items.ts +20 -0
  240. package/src/migrations/sql/20231216100720-player-inventory.ts +16 -0
  241. package/src/migrations/sql/20231222180438-steam-data.ts +27 -0
  242. package/src/migrations/sql/20231223132631-pog-online.ts +13 -0
  243. package/src/migrations/sql/20231223212031-unique-index-item-def.ts +27 -0
  244. package/src/migrations/sql/20231224135126-gameserver-online-status.ts +13 -0
  245. package/src/migrations/sql/20231224155226-unique-pog.ts +27 -0
  246. package/src/migrations/sql/20231225140650-extra-ip-info.ts +27 -0
  247. package/src/migrations/sql/20231227144315-unique-constraints-player.ts +74 -0
  248. package/src/migrations/sql/20231229144707-more-player-constraints.ts +20 -0
  249. package/src/migrations/sql/20240101162751-add-settings-constraint.ts +39 -0
  250. package/src/migrations/sql/20240105130846-remove-some-module-perms.ts +104 -0
  251. package/src/migrations/sql/20240116141936-add-ui-schema-to-module.ts +13 -0
  252. package/src/migrations/sql/20240119152426-remove-hook-check.ts +18 -0
  253. package/src/migrations/sql/20240121142329-move-ip-history.ts +53 -0
  254. package/src/migrations/sql/20240202101208-rename-economy-to-economyUtils.ts +15 -0
  255. package/src/migrations/sql/20240216120143-domain-state.ts +13 -0
  256. package/src/migrations/sql/20240229141340-looser-fks-events.ts +20 -0
  257. package/src/migrations/sql/20240301063505-module-functions.ts +17 -0
  258. package/src/migrations/util/alterEnum.ts +10 -0
  259. package/src/queryBuilder.ts +133 -0
  260. package/src/redis.ts +58 -0
  261. package/tsconfig.build.json +9 -0
  262. package/tsconfig.json +8 -0
  263. package/typedoc.json +3 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231223132631-pog-online.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231223132631-pog-online.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,24 @@
1
+ export async function up(knex) {
2
+ // Delete duplicates while keeping the first occurrence
3
+ await knex.raw(`
4
+ DELETE FROM items
5
+ WHERE id IN (
6
+ SELECT id
7
+ FROM (
8
+ SELECT id,
9
+ ROW_NUMBER() OVER (PARTITION BY code, "gameserverId", domain ORDER BY id) as rnk
10
+ FROM items
11
+ ) t
12
+ WHERE t.rnk > 1
13
+ )
14
+ `);
15
+ await knex.schema.alterTable('items', (table) => {
16
+ table.unique(['code', 'gameserverId', 'domain']);
17
+ });
18
+ }
19
+ export async function down(knex) {
20
+ await knex.schema.alterTable('items', (table) => {
21
+ table.dropUnique(['code', 'gameserverId', 'domain']);
22
+ });
23
+ }
24
+ //# sourceMappingURL=20231223212031-unique-index-item-def.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231223212031-unique-index-item-def.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231223212031-unique-index-item-def.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,uDAAuD;IACvD,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;GAWd,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;QAC9C,KAAK,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;QAC9C,KAAK,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,11 @@
1
+ export async function up(knex) {
2
+ await knex.schema.alterTable('gameservers', (table) => {
3
+ table.boolean('reachable').defaultTo(true);
4
+ });
5
+ }
6
+ export async function down(knex) {
7
+ await knex.schema.alterTable('gameservers', (table) => {
8
+ table.dropColumn('reachable');
9
+ });
10
+ }
11
+ //# sourceMappingURL=20231224135126-gameserver-online-status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231224135126-gameserver-online-status.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231224135126-gameserver-online-status.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE;QACpD,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE;QACpD,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,24 @@
1
+ export async function up(knex) {
2
+ // Delete duplicate rows first
3
+ await knex.raw(`
4
+ DELETE FROM "playerOnGameServer"
5
+ WHERE id IN (
6
+ SELECT id
7
+ FROM (
8
+ SELECT id,
9
+ ROW_NUMBER() OVER (PARTITION BY "gameId", "gameServerId" ORDER BY id) as rnk
10
+ FROM "playerOnGameServer"
11
+ ) t
12
+ WHERE t.rnk > 1
13
+ )
14
+ `);
15
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
16
+ table.unique(['gameId', 'gameServerId']);
17
+ });
18
+ }
19
+ export async function down(knex) {
20
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
21
+ table.dropUnique(['gameId', 'gameServerId']);
22
+ });
23
+ }
24
+ //# sourceMappingURL=20231224155226-unique-pog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231224155226-unique-pog.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231224155226-unique-pog.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,8BAA8B;IAC9B,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;GAWd,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,23 @@
1
+ export async function up(knex) {
2
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
3
+ table.dropColumn('ip');
4
+ });
5
+ await knex.schema.createTable('playerOnGameServerIp', (table) => {
6
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
7
+ table.timestamps(true, true, true);
8
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
9
+ table.uuid('pogId').references('playerOnGameServer.id').onDelete('CASCADE').notNullable();
10
+ table.specificType('ip', 'inet').notNullable();
11
+ table.string('country');
12
+ table.string('city');
13
+ table.string('longitude');
14
+ table.string('latitude');
15
+ });
16
+ }
17
+ export async function down(knex) {
18
+ await knex.schema.dropTable('playerOnGameServerIp');
19
+ await knex.schema.alterTable('playerOnGameServer', (table) => {
20
+ table.specificType('ip', 'inet').nullable();
21
+ });
22
+ }
23
+ //# sourceMappingURL=20231225140650-extra-ip-info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231225140650-extra-ip-info.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231225140650-extra-ip-info.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC9D,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACrE,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACnC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAClF,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,uBAAuB,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAC1F,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/C,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACxB,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrB,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QAC1B,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;IAEpD,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3D,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,67 @@
1
+ export async function up(knex) {
2
+ // Delete any duplicate rows first
3
+ // Retain the record where createdAt is the oldest
4
+ await knex.raw(`
5
+ DELETE FROM "players"
6
+ WHERE id IN (
7
+ SELECT id
8
+ FROM (
9
+ SELECT id,
10
+ ROW_NUMBER() OVER (PARTITION BY domain, "steamId" ORDER BY "createdAt") as rnk
11
+ FROM "players"
12
+ WHERE "steamId" IS NOT NULL
13
+ ) t
14
+ WHERE t.rnk > 1
15
+ )
16
+ `);
17
+ // Also for epicOnlineServicesId
18
+ await knex.raw(`
19
+ DELETE FROM "players"
20
+ WHERE id IN (
21
+ SELECT id
22
+ FROM (
23
+ SELECT id,
24
+ ROW_NUMBER() OVER (PARTITION BY domain, "epicOnlineServicesId" ORDER BY "createdAt") as rnk
25
+ FROM "players"
26
+ WHERE "epicOnlineServicesId" IS NOT NULL
27
+ ) t
28
+ WHERE t.rnk > 1
29
+ )
30
+ `);
31
+ // And xbox
32
+ await knex.raw(`
33
+ DELETE FROM "players"
34
+ WHERE id IN (
35
+ SELECT id
36
+ FROM (
37
+ SELECT id,
38
+ ROW_NUMBER() OVER (PARTITION BY domain, "xboxLiveId" ORDER BY "createdAt") as rnk
39
+ FROM "players"
40
+ WHERE "xboxLiveId" IS NOT NULL
41
+ ) t
42
+ WHERE t.rnk > 1
43
+ )
44
+ `);
45
+ await knex.schema.alterTable('players', (table) => {
46
+ table.unique(['domain', 'steamId']);
47
+ table.unique(['domain', 'epicOnlineServicesId']);
48
+ table.unique(['domain', 'xboxLiveId']);
49
+ });
50
+ await knex.raw(`
51
+ ALTER TABLE players
52
+ ADD CONSTRAINT players_domain_steam_xbox_eos_unique
53
+ UNIQUE NULLS NOT DISTINCT (domain, "steamId", "xboxLiveId", "epicOnlineServicesId");
54
+ `);
55
+ }
56
+ export async function down(knex) {
57
+ await knex.schema.alterTable('players', (table) => {
58
+ table.dropUnique(['domain', 'steamId']);
59
+ table.dropUnique(['domain', 'epicOnlineServicesId']);
60
+ table.dropUnique(['domain', 'xboxLiveId']);
61
+ });
62
+ await knex.raw(`
63
+ ALTER TABLE players
64
+ DROP CONSTRAINT players_domain_steam_xbox_eos_unique;
65
+ `);
66
+ }
67
+ //# sourceMappingURL=20231227144315-unique-constraints-player.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231227144315-unique-constraints-player.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231227144315-unique-constraints-player.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,kCAAkC;IAClC,kDAAkD;IAClD,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;;GAYd,CAAC,CAAC;IAEH,gCAAgC;IAChC,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;;GAYd,CAAC,CAAC;IAEH,WAAW;IACX,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;;GAYd,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;QACpC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,sBAAsB,CAAC,CAAC,CAAC;QACjD,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,GAAG,CAAC;;;;CAIhB,CAAC,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;QACxC,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,sBAAsB,CAAC,CAAC,CAAC;QACrD,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,GAAG,CAAC;;;GAGd,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,17 @@
1
+ export async function up(knex) {
2
+ // Find all players that have epicOnlineServicesId starting with EOS_ and delete them
3
+ await knex.raw(`
4
+ DELETE FROM "players"
5
+ WHERE "epicOnlineServicesId" LIKE 'EOS_%'
6
+ `);
7
+ await knex.schema.alterTable('players', (table) => {
8
+ // epicOnlineServicesId is always 32 chars
9
+ table.string('epicOnlineServicesId', 32).alter();
10
+ });
11
+ }
12
+ export async function down(knex) {
13
+ await knex.schema.alterTable('players', (table) => {
14
+ table.string('epicOnlineServicesId', 255).alter();
15
+ });
16
+ }
17
+ //# sourceMappingURL=20231229144707-more-player-constraints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20231229144707-more-player-constraints.js","sourceRoot":"","sources":["../../../src/migrations/sql/20231229144707-more-player-constraints.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,qFAAqF;IACrF,MAAM,IAAI,CAAC,GAAG,CAAC;;;GAGd,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,0CAA0C;QAC1C,KAAK,CAAC,MAAM,CAAC,sBAAsB,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,MAAM,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,34 @@
1
+ export async function up(knex) {
2
+ // Delete any settings where duplicate key, same domain and null gameServerId
3
+ await knex.raw(`
4
+ DELETE FROM settings
5
+ WHERE id IN (
6
+ SELECT id
7
+ FROM (
8
+ SELECT id, ROW_NUMBER() OVER (partition BY key, domain ORDER BY id) AS rnum
9
+ FROM settings
10
+ WHERE "gameServerId" IS NULL
11
+ ) t
12
+ WHERE t.rnum > 1
13
+ );
14
+ `);
15
+ // Drop the old constraint
16
+ await knex.schema.alterTable('settings', (table) => {
17
+ table.dropUnique(['key', 'domain', 'gameServerId'], 'new_settings_domain_key_gameserverid_unique');
18
+ });
19
+ await knex.raw(`
20
+ ALTER TABLE settings
21
+ ADD CONSTRAINT settings_key_domain_unique
22
+ UNIQUE NULLS NOT DISTINCT (key, domain, "gameServerId");
23
+ `);
24
+ }
25
+ export async function down(knex) {
26
+ await knex.raw(`
27
+ ALTER TABLE settings
28
+ DROP CONSTRAINT settings_key_domain_unique;
29
+ `);
30
+ await knex.schema.alterTable('settings', (table) => {
31
+ table.unique(['key', 'domain', 'gameServerId'], 'new_settings_domain_key_gameserverid_unique');
32
+ });
33
+ }
34
+ //# sourceMappingURL=20240101162751-add-settings-constraint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240101162751-add-settings-constraint.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240101162751-add-settings-constraint.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,6EAA6E;IAC7E,MAAM,IAAI,CAAC,GAAG,CAAC;;;;;;;;;;;GAWd,CAAC,CAAC;IAEH,0BAA0B;IAC1B,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC,KAAK,EAAE,EAAE;QACjD,KAAK,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,CAAC,EAAE,6CAA6C,CAAC,CAAC;IACrG,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,GAAG,CAAC;;;;CAIhB,CAAC,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,GAAG,CAAC;;;GAGd,CAAC,CAAC;IAEH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC,KAAK,EAAE,EAAE;QACjD,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,CAAC,EAAE,6CAA6C,CAAC,CAAC;IACjG,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,80 @@
1
+ export async function up(knex) {
2
+ // All perms to-be-deleted
3
+ const readPermissions = ['READ_FUNCTIONS', 'READ_CRONJOBS', 'READ_HOOKS', 'READ_COMMANDS'];
4
+ const managePermissions = ['MANAGE_FUNCTIONS', 'MANAGE_CRONJOBS', 'MANAGE_HOOKS', 'MANAGE_COMMANDS'];
5
+ // First, find all permissions that are to be deleted
6
+ const readPerms = await knex('permission').whereIn('permission', readPermissions).select('id');
7
+ const managePerms = await knex('permission').whereIn('permission', managePermissions).select('id');
8
+ // Then, find the READ_MODULES and MANAGE_MODULES permissions
9
+ const readModulePerm = await knex('permission').where('permission', 'READ_MODULES').select('id').first();
10
+ const manageModulePerm = await knex('permission').where('permission', 'MANAGE_MODULES').select('id').first();
11
+ // Then, find all permissionOnRole entries that reference those permissions
12
+ const readPermissionOnRole = await knex('permissionOnRole')
13
+ .whereIn('permissionId', readPerms.map((p) => p.id))
14
+ .select('id');
15
+ const managePermissionOnRole = await knex('permissionOnRole')
16
+ .whereIn('permissionId', managePerms.map((p) => p.id))
17
+ .select('id');
18
+ // Then, update the permissionOnRole entries to reference the new permissions
19
+ await knex('permissionOnRole')
20
+ .whereIn('id', readPermissionOnRole.map((p) => p.id))
21
+ .update({
22
+ permissionId: readModulePerm.id,
23
+ });
24
+ await knex('permissionOnRole')
25
+ .whereIn('id', managePermissionOnRole.map((p) => p.id))
26
+ .update({
27
+ permissionId: manageModulePerm.id,
28
+ });
29
+ // Then, delete the old perms
30
+ await knex('permission')
31
+ .whereIn('permission', [...readPermissions, ...managePermissions])
32
+ .del();
33
+ }
34
+ export async function down(knex) {
35
+ // Cant actually undo this, we deleted the data (:
36
+ // Just put back the old perms
37
+ await knex('permission').insert([
38
+ {
39
+ permission: 'READ_FUNCTIONS',
40
+ description: 'Read functions',
41
+ friendlyName: 'Read Functions',
42
+ },
43
+ {
44
+ permission: 'READ_CRONJOBS',
45
+ description: 'Read cronjobs',
46
+ friendlyName: 'Read Cronjobs',
47
+ },
48
+ {
49
+ permission: 'READ_HOOKS',
50
+ description: 'Read hooks',
51
+ friendlyName: 'Read Hooks',
52
+ },
53
+ {
54
+ permission: 'READ_COMMANDS',
55
+ description: 'Read commands',
56
+ friendlyName: 'Read Commands',
57
+ },
58
+ {
59
+ permission: 'MANAGE_FUNCTIONS',
60
+ description: 'Manage functions',
61
+ friendlyName: 'Manage Functions',
62
+ },
63
+ {
64
+ permission: 'MANAGE_CRONJOBS',
65
+ description: 'Manage cronjobs',
66
+ friendlyName: 'Manage Cronjobs',
67
+ },
68
+ {
69
+ permission: 'MANAGE_HOOKS',
70
+ description: 'Manage hooks',
71
+ friendlyName: 'Manage Hooks',
72
+ },
73
+ {
74
+ permission: 'MANAGE_COMMANDS',
75
+ description: 'Manage commands',
76
+ friendlyName: 'Manage Commands',
77
+ },
78
+ ]);
79
+ }
80
+ //# sourceMappingURL=20240105130846-remove-some-module-perms.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240105130846-remove-some-module-perms.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240105130846-remove-some-module-perms.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,11 @@
1
+ export async function up(knex) {
2
+ await knex.schema.alterTable('modules', (table) => {
3
+ table.text('uiSchema').defaultTo('{}').notNullable();
4
+ });
5
+ }
6
+ export async function down(knex) {
7
+ await knex.schema.alterTable('modules', (table) => {
8
+ table.dropColumn('uiSchema');
9
+ });
10
+ }
11
+ //# sourceMappingURL=20240116141936-add-ui-schema-to-module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240116141936-add-ui-schema-to-module.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240116141936-add-ui-schema-to-module.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,14 @@
1
+ import { formatAlterTableEnumSql } from '../util/alterEnum.js';
2
+ export async function up(knex) {
3
+ await knex.raw('ALTER TABLE hooks DROP CONSTRAINT "hooks_eventType_check";');
4
+ }
5
+ export async function down(knex) {
6
+ await knex.raw(formatAlterTableEnumSql('hooks', 'eventType', [
7
+ 'log',
8
+ 'player-connected',
9
+ 'player-disconnected',
10
+ 'chat-message',
11
+ 'discord-message',
12
+ ]));
13
+ }
14
+ //# sourceMappingURL=20240119152426-remove-hook-check.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240119152426-remove-hook-check.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240119152426-remove-hook-check.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAE/D,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,GAAG,CAAC,4DAA4D,CAAC,CAAC;AAC/E,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,GAAG,CACZ,uBAAuB,CAAC,OAAO,EAAE,WAAW,EAAE;QAC5C,KAAK;QACL,kBAAkB;QAClB,qBAAqB;QACrB,cAAc;QACd,iBAAiB;KAClB,CAAC,CACH,CAAC;AACJ,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,44 @@
1
+ export async function up(knex) {
2
+ await knex.schema.createTable('playerIpHistory', (table) => {
3
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
4
+ table.timestamps(true, true, true);
5
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
6
+ table.uuid('playerId').references('players.id').onDelete('CASCADE').notNullable();
7
+ table.uuid('gameServerId').references('gameservers.id').onDelete('SET NULL').nullable();
8
+ table.specificType('ip', 'inet').notNullable();
9
+ table.string('country');
10
+ table.string('city');
11
+ table.string('longitude');
12
+ table.string('latitude');
13
+ });
14
+ // Transfer all the old IP history to new table
15
+ const oldIpHistory = await knex('playerOnGameServerIp').select('*');
16
+ const newRecords = await Promise.all(oldIpHistory.map(async (ipHistory) => {
17
+ const pog = await knex('playerOnGameServer').select('*').where('id', ipHistory.pogId).first();
18
+ delete ipHistory.pogId;
19
+ return {
20
+ ...ipHistory,
21
+ playerId: pog.playerId,
22
+ gameServerId: pog.gameServerId,
23
+ };
24
+ }));
25
+ if (newRecords.length) {
26
+ await knex('playerIpHistory').insert(newRecords);
27
+ }
28
+ await knex.schema.dropTable('playerOnGameServerIp');
29
+ }
30
+ export async function down(knex) {
31
+ await knex.schema.dropTable('playerIpHistory');
32
+ await knex.schema.createTable('playerOnGameServerIp', (table) => {
33
+ table.uuid('id').primary().defaultTo(knex.raw('gen_random_uuid ()'));
34
+ table.timestamps(true, true, true);
35
+ table.string('domain').references('domains.id').onDelete('CASCADE').notNullable();
36
+ table.uuid('pogId').references('playerOnGameServer.id').onDelete('CASCADE').notNullable();
37
+ table.specificType('ip', 'inet').notNullable();
38
+ table.string('country');
39
+ table.string('city');
40
+ table.string('longitude');
41
+ table.string('latitude');
42
+ });
43
+ }
44
+ //# sourceMappingURL=20240121142329-move-ip-history.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240121142329-move-ip-history.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240121142329-move-ip-history.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,13 @@
1
+ export async function up(knex) {
2
+ await knex('modules').where('builtin', '=', 'economy').update({
3
+ builtin: 'economyUtils',
4
+ name: 'economyUtils',
5
+ });
6
+ }
7
+ export async function down(knex) {
8
+ await knex('modules').where('builtin', '=', 'economyUtils').update({
9
+ builtin: 'economy',
10
+ name: 'economy',
11
+ });
12
+ }
13
+ //# sourceMappingURL=20240202101208-rename-economy-to-economyUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240202101208-rename-economy-to-economyUtils.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240202101208-rename-economy-to-economyUtils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC;QAC5D,OAAO,EAAE,cAAc;QACvB,IAAI,EAAE,cAAc;KACrB,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC,MAAM,CAAC;QACjE,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,SAAS;KAChB,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,11 @@
1
+ export async function up(knex) {
2
+ await knex.schema.alterTable('domains', (table) => {
3
+ table.enum('state', ['ACTIVE', 'DISABLED', 'MAINTENANCE']).notNullable().defaultTo('ACTIVE');
4
+ });
5
+ }
6
+ export async function down(knex) {
7
+ await knex.schema.alterTable('domains', (table) => {
8
+ table.dropColumn('state');
9
+ });
10
+ }
11
+ //# sourceMappingURL=20240216120143-domain-state.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240216120143-domain-state.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240216120143-domain-state.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IAC/F,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;QAChD,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,18 @@
1
+ export async function up(knex) {
2
+ // When player, module, gameserver or userId is deleted, keep the event
3
+ await knex.schema.alterTable('events', (table) => {
4
+ table.dropForeign(['playerId']);
5
+ table.dropForeign(['moduleId']);
6
+ table.dropForeign(['gameserverId']);
7
+ table.dropForeign(['userId']);
8
+ });
9
+ }
10
+ export async function down(knex) {
11
+ await knex.schema.alterTable('events', (table) => {
12
+ table.foreign('playerId').references('id').inTable('players').onDelete('CASCADE');
13
+ table.foreign('moduleId').references('id').inTable('modules').onDelete('CASCADE');
14
+ table.foreign('gameserverId').references('id').inTable('gameservers').onDelete('CASCADE');
15
+ table.foreign('userId').references('id').inTable('users').onDelete('CASCADE');
16
+ });
17
+ }
18
+ //# sourceMappingURL=20240229141340-looser-fks-events.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240229141340-looser-fks-events.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240229141340-looser-fks-events.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,uEAAuE;IACvE,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;QAC/C,KAAK,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;QAChC,KAAK,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;QAChC,KAAK,CAAC,WAAW,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC;QACpC,KAAK,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;QAC/C,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAClF,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAClF,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAC1F,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAChF,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Knex } from 'knex';
2
+ export declare function up(knex: Knex): Promise<void>;
3
+ export declare function down(knex: Knex): Promise<void>;
@@ -0,0 +1,14 @@
1
+ export async function up(knex) {
2
+ await knex.schema.alterTable('functions', (table) => {
3
+ table.string('name').nullable();
4
+ table.uuid('moduleId').nullable();
5
+ table.foreign('moduleId').references('id').inTable('modules');
6
+ });
7
+ }
8
+ export async function down(knex) {
9
+ await knex.schema.dropTable('module_functions');
10
+ await knex.schema.alterTable('functions', (table) => {
11
+ table.dropColumn('name');
12
+ });
13
+ }
14
+ //# sourceMappingURL=20240301063505-module-functions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20240301063505-module-functions.js","sourceRoot":"","sources":["../../../src/migrations/sql/20240301063505-module-functions.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE;QAClD,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QAClC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;IAEhD,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE;QAClD,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1 @@
1
+ export declare function formatAlterTableEnumSql(tableName: string, columnName: string, enums: string[]): string;
@@ -0,0 +1,9 @@
1
+ /* eslint-disable quotes */
2
+ export function formatAlterTableEnumSql(tableName, columnName, enums) {
3
+ const constraintName = `${tableName}_${columnName}_check`;
4
+ return [
5
+ `ALTER TABLE "${tableName}" DROP CONSTRAINT IF EXISTS "${constraintName}";`,
6
+ `ALTER TABLE "${tableName}" ADD CONSTRAINT "${constraintName}" CHECK ("${columnName}" = ANY (ARRAY['${enums.join("'::text, '")}'::text]));`,
7
+ ].join('\n');
8
+ }
9
+ //# sourceMappingURL=alterEnum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alterEnum.js","sourceRoot":"","sources":["../../../src/migrations/util/alterEnum.ts"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,MAAM,UAAU,uBAAuB,CAAC,SAAiB,EAAE,UAAkB,EAAE,KAAe;IAC5F,MAAM,cAAc,GAAG,GAAG,SAAS,IAAI,UAAU,QAAQ,CAAC;IAC1D,OAAO;QACL,gBAAgB,SAAS,gCAAgC,cAAc,IAAI;QAC3E,gBAAgB,SAAS,qBAAqB,cAAc,aAAa,UAAU,mBAAmB,KAAK,CAAC,IAAI,CAC9G,YAAY,CACb,aAAa;KACf,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC"}