@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.
- package/README.md +1 -0
- package/dist/TakaroModel.d.ts +15 -0
- package/dist/TakaroModel.js +23 -0
- package/dist/TakaroModel.js.map +1 -0
- package/dist/config.d.ts +98 -0
- package/dist/config.js +81 -0
- package/dist/config.js.map +1 -0
- package/dist/encryption.d.ts +4 -0
- package/dist/encryption.js +24 -0
- package/dist/encryption.js.map +1 -0
- package/dist/errorTypeGuards.d.ts +2 -0
- package/dist/errorTypeGuards.js +11 -0
- package/dist/errorTypeGuards.js.map +1 -0
- package/dist/knex.d.ts +16 -0
- package/dist/knex.js +46 -0
- package/dist/knex.js.map +1 -0
- package/dist/main.d.ts +8 -0
- package/dist/main.js +9 -0
- package/dist/main.js.map +1 -0
- package/dist/migrations/index.d.ts +2 -0
- package/dist/migrations/index.js +59 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/migrations/sql/20220827191938_init.d.ts +3 -0
- package/dist/migrations/sql/20220827191938_init.js +155 -0
- package/dist/migrations/sql/20220827191938_init.js.map +1 -0
- package/dist/migrations/sql/20221019173729_settings.d.ts +3 -0
- package/dist/migrations/sql/20221019173729_settings.js +61 -0
- package/dist/migrations/sql/20221019173729_settings.js.map +1 -0
- package/dist/migrations/sql/20221029103554_refactor_function_assignments.d.ts +3 -0
- package/dist/migrations/sql/20221029103554_refactor_function_assignments.js +33 -0
- package/dist/migrations/sql/20221029103554_refactor_function_assignments.js.map +1 -0
- package/dist/migrations/sql/20221102190532_commands.d.ts +3 -0
- package/dist/migrations/sql/20221102190532_commands.js +58 -0
- package/dist/migrations/sql/20221102190532_commands.js.map +1 -0
- package/dist/migrations/sql/20221203135001-builtin_modules.d.ts +3 -0
- package/dist/migrations/sql/20221203135001-builtin_modules.js +44 -0
- package/dist/migrations/sql/20221203135001-builtin_modules.js.map +1 -0
- package/dist/migrations/sql/20230308183400-persistent-variables.d.ts +3 -0
- package/dist/migrations/sql/20230308183400-persistent-variables.js +63 -0
- package/dist/migrations/sql/20230308183400-persistent-variables.js.map +1 -0
- package/dist/migrations/sql/20230314183400-auth-ory.d.ts +3 -0
- package/dist/migrations/sql/20230314183400-auth-ory.js +23 -0
- package/dist/migrations/sql/20230314183400-auth-ory.js.map +1 -0
- package/dist/migrations/sql/20230325156123_command-arguments.d.ts +3 -0
- package/dist/migrations/sql/20230325156123_command-arguments.js +19 -0
- package/dist/migrations/sql/20230325156123_command-arguments.js.map +1 -0
- package/dist/migrations/sql/20230407132022-module-descriptions.d.ts +3 -0
- package/dist/migrations/sql/20230407132022-module-descriptions.js +11 -0
- package/dist/migrations/sql/20230407132022-module-descriptions.js.map +1 -0
- package/dist/migrations/sql/20230407143733-module-json-schema-config.d.ts +3 -0
- package/dist/migrations/sql/20230407143733-module-json-schema-config.js +14 -0
- package/dist/migrations/sql/20230407143733-module-json-schema-config.js.map +1 -0
- package/dist/migrations/sql/20230407173055-hook-regex-optional.d.ts +3 -0
- package/dist/migrations/sql/20230407173055-hook-regex-optional.js +11 -0
- package/dist/migrations/sql/20230407173055-hook-regex-optional.js.map +1 -0
- package/dist/migrations/sql/20230415154935-cronjob-configs.d.ts +3 -0
- package/dist/migrations/sql/20230415154935-cronjob-configs.js +16 -0
- package/dist/migrations/sql/20230415154935-cronjob-configs.js.map +1 -0
- package/dist/migrations/sql/20230503132906-variables-extra-meta.d.ts +3 -0
- package/dist/migrations/sql/20230503132906-variables-extra-meta.js +26 -0
- package/dist/migrations/sql/20230503132906-variables-extra-meta.js.map +1 -0
- package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.d.ts +3 -0
- package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js +8 -0
- package/dist/migrations/sql/20230604130951-fix-hook-eventtypes.js.map +1 -0
- package/dist/migrations/sql/20230617081049-discordId-for-users.d.ts +3 -0
- package/dist/migrations/sql/20230617081049-discordId-for-users.js +14 -0
- package/dist/migrations/sql/20230617081049-discordId-for-users.js.map +1 -0
- package/dist/migrations/sql/20230618053611-discord-funtionality.d.ts +3 -0
- package/dist/migrations/sql/20230618053611-discord-funtionality.js +26 -0
- package/dist/migrations/sql/20230618053611-discord-funtionality.js.map +1 -0
- package/dist/migrations/sql/20230622192402-discord-hooks.d.ts +3 -0
- package/dist/migrations/sql/20230622192402-discord-hooks.js +14 -0
- package/dist/migrations/sql/20230622192402-discord-hooks.js.map +1 -0
- package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.d.ts +3 -0
- package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js +19 -0
- package/dist/migrations/sql/20230707081218-playerOnGameServerExtension.js.map +1 -0
- package/dist/migrations/sql/20230710174340-events.d.ts +3 -0
- package/dist/migrations/sql/20230710174340-events.js +16 -0
- package/dist/migrations/sql/20230710174340-events.js.map +1 -0
- package/dist/migrations/sql/20230712061220-roles-permissions-extension.d.ts +3 -0
- package/dist/migrations/sql/20230712061220-roles-permissions-extension.js +43 -0
- package/dist/migrations/sql/20230712061220-roles-permissions-extension.js.map +1 -0
- package/dist/migrations/sql/20230713184927-variables-modulescoped.d.ts +3 -0
- package/dist/migrations/sql/20230713184927-variables-modulescoped.js +27 -0
- package/dist/migrations/sql/20230713184927-variables-modulescoped.js.map +1 -0
- package/dist/migrations/sql/20230714045136-domain-index.d.ts +3 -0
- package/dist/migrations/sql/20230714045136-domain-index.js +37 -0
- package/dist/migrations/sql/20230714045136-domain-index.js.map +1 -0
- package/dist/migrations/sql/20230714045727-events-index.d.ts +3 -0
- package/dist/migrations/sql/20230714045727-events-index.js +17 -0
- package/dist/migrations/sql/20230714045727-events-index.js.map +1 -0
- package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.d.ts +3 -0
- package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js +32 -0
- package/dist/migrations/sql/20230715102519-module-permissions-extra-fields.js.map +1 -0
- package/dist/migrations/sql/20230724062109-roles-constraints.d.ts +3 -0
- package/dist/migrations/sql/20230724062109-roles-constraints.js +14 -0
- package/dist/migrations/sql/20230724062109-roles-constraints.js.map +1 -0
- package/dist/migrations/sql/20230811095701-userId-on-events.d.ts +3 -0
- package/dist/migrations/sql/20230811095701-userId-on-events.js +12 -0
- package/dist/migrations/sql/20230811095701-userId-on-events.js.map +1 -0
- package/dist/migrations/sql/20230921123717-count-for-permissions.d.ts +3 -0
- package/dist/migrations/sql/20230921123717-count-for-permissions.js +84 -0
- package/dist/migrations/sql/20230921123717-count-for-permissions.js.map +1 -0
- package/dist/migrations/sql/20231111102812-details-system-permissions.d.ts +36 -0
- package/dist/migrations/sql/20231111102812-details-system-permissions.js +179 -0
- package/dist/migrations/sql/20231111102812-details-system-permissions.js.map +1 -0
- package/dist/migrations/sql/20231114151343-system-roles.d.ts +3 -0
- package/dist/migrations/sql/20231114151343-system-roles.js +41 -0
- package/dist/migrations/sql/20231114151343-system-roles.js.map +1 -0
- package/dist/migrations/sql/20231118082301-add-new-permissions.d.ts +36 -0
- package/dist/migrations/sql/20231118082301-add-new-permissions.js +186 -0
- package/dist/migrations/sql/20231118082301-add-new-permissions.js.map +1 -0
- package/dist/migrations/sql/20231119115037-timedRoles.d.ts +3 -0
- package/dist/migrations/sql/20231119115037-timedRoles.js +19 -0
- package/dist/migrations/sql/20231119115037-timedRoles.js.map +1 -0
- package/dist/migrations/sql/20231123150854-economy-base.d.ts +3 -0
- package/dist/migrations/sql/20231123150854-economy-base.js +13 -0
- package/dist/migrations/sql/20231123150854-economy-base.js.map +1 -0
- package/dist/migrations/sql/20231123171611-economy-settings.d.ts +3 -0
- package/dist/migrations/sql/20231123171611-economy-settings.js +13 -0
- package/dist/migrations/sql/20231123171611-economy-settings.js.map +1 -0
- package/dist/migrations/sql/20231124140441-json-module-assignments.d.ts +3 -0
- package/dist/migrations/sql/20231124140441-json-module-assignments.js +25 -0
- package/dist/migrations/sql/20231124140441-json-module-assignments.js.map +1 -0
- package/dist/migrations/sql/20231208114507-settings-refactor.d.ts +3 -0
- package/dist/migrations/sql/20231208114507-settings-refactor.js +95 -0
- package/dist/migrations/sql/20231208114507-settings-refactor.js.map +1 -0
- package/dist/migrations/sql/20231208171234-game-items.d.ts +3 -0
- package/dist/migrations/sql/20231208171234-game-items.js +18 -0
- package/dist/migrations/sql/20231208171234-game-items.js.map +1 -0
- package/dist/migrations/sql/20231216100720-player-inventory.d.ts +3 -0
- package/dist/migrations/sql/20231216100720-player-inventory.js +14 -0
- package/dist/migrations/sql/20231216100720-player-inventory.js.map +1 -0
- package/dist/migrations/sql/20231222180438-steam-data.d.ts +3 -0
- package/dist/migrations/sql/20231222180438-steam-data.js +25 -0
- package/dist/migrations/sql/20231222180438-steam-data.js.map +1 -0
- package/dist/migrations/sql/20231223132631-pog-online.d.ts +3 -0
- package/dist/migrations/sql/20231223132631-pog-online.js +11 -0
- package/dist/migrations/sql/20231223132631-pog-online.js.map +1 -0
- package/dist/migrations/sql/20231223212031-unique-index-item-def.d.ts +3 -0
- package/dist/migrations/sql/20231223212031-unique-index-item-def.js +24 -0
- package/dist/migrations/sql/20231223212031-unique-index-item-def.js.map +1 -0
- package/dist/migrations/sql/20231224135126-gameserver-online-status.d.ts +3 -0
- package/dist/migrations/sql/20231224135126-gameserver-online-status.js +11 -0
- package/dist/migrations/sql/20231224135126-gameserver-online-status.js.map +1 -0
- package/dist/migrations/sql/20231224155226-unique-pog.d.ts +3 -0
- package/dist/migrations/sql/20231224155226-unique-pog.js +24 -0
- package/dist/migrations/sql/20231224155226-unique-pog.js.map +1 -0
- package/dist/migrations/sql/20231225140650-extra-ip-info.d.ts +3 -0
- package/dist/migrations/sql/20231225140650-extra-ip-info.js +23 -0
- package/dist/migrations/sql/20231225140650-extra-ip-info.js.map +1 -0
- package/dist/migrations/sql/20231227144315-unique-constraints-player.d.ts +3 -0
- package/dist/migrations/sql/20231227144315-unique-constraints-player.js +67 -0
- package/dist/migrations/sql/20231227144315-unique-constraints-player.js.map +1 -0
- package/dist/migrations/sql/20231229144707-more-player-constraints.d.ts +3 -0
- package/dist/migrations/sql/20231229144707-more-player-constraints.js +17 -0
- package/dist/migrations/sql/20231229144707-more-player-constraints.js.map +1 -0
- package/dist/migrations/sql/20240101162751-add-settings-constraint.d.ts +3 -0
- package/dist/migrations/sql/20240101162751-add-settings-constraint.js +34 -0
- package/dist/migrations/sql/20240101162751-add-settings-constraint.js.map +1 -0
- package/dist/migrations/sql/20240105130846-remove-some-module-perms.d.ts +3 -0
- package/dist/migrations/sql/20240105130846-remove-some-module-perms.js +80 -0
- package/dist/migrations/sql/20240105130846-remove-some-module-perms.js.map +1 -0
- package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.d.ts +3 -0
- package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js +11 -0
- package/dist/migrations/sql/20240116141936-add-ui-schema-to-module.js.map +1 -0
- package/dist/migrations/sql/20240119152426-remove-hook-check.d.ts +3 -0
- package/dist/migrations/sql/20240119152426-remove-hook-check.js +14 -0
- package/dist/migrations/sql/20240119152426-remove-hook-check.js.map +1 -0
- package/dist/migrations/sql/20240121142329-move-ip-history.d.ts +3 -0
- package/dist/migrations/sql/20240121142329-move-ip-history.js +44 -0
- package/dist/migrations/sql/20240121142329-move-ip-history.js.map +1 -0
- package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.d.ts +3 -0
- package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js +13 -0
- package/dist/migrations/sql/20240202101208-rename-economy-to-economyUtils.js.map +1 -0
- package/dist/migrations/sql/20240216120143-domain-state.d.ts +3 -0
- package/dist/migrations/sql/20240216120143-domain-state.js +11 -0
- package/dist/migrations/sql/20240216120143-domain-state.js.map +1 -0
- package/dist/migrations/sql/20240229141340-looser-fks-events.d.ts +3 -0
- package/dist/migrations/sql/20240229141340-looser-fks-events.js +18 -0
- package/dist/migrations/sql/20240229141340-looser-fks-events.js.map +1 -0
- package/dist/migrations/sql/20240301063505-module-functions.d.ts +3 -0
- package/dist/migrations/sql/20240301063505-module-functions.js +14 -0
- package/dist/migrations/sql/20240301063505-module-functions.js.map +1 -0
- package/dist/migrations/util/alterEnum.d.ts +1 -0
- package/dist/migrations/util/alterEnum.js +9 -0
- package/dist/migrations/util/alterEnum.js.map +1 -0
- package/dist/queryBuilder.d.ts +28 -0
- package/dist/queryBuilder.js +132 -0
- package/dist/queryBuilder.js.map +1 -0
- package/dist/redis.d.ts +20 -0
- package/dist/redis.js +49 -0
- package/dist/redis.js.map +1 -0
- package/package.json +29 -0
- package/src/TakaroModel.ts +32 -0
- package/src/__tests__/encryption.integration.test.ts +56 -0
- package/src/__tests__/queryBuilder.integration.test.ts +202 -0
- package/src/config.ts +101 -0
- package/src/encryption.ts +27 -0
- package/src/errorTypeGuards.ts +11 -0
- package/src/knex.ts +54 -0
- package/src/main.ts +15 -0
- package/src/migrations/index.ts +70 -0
- package/src/migrations/sql/20220827191938_init.ts +183 -0
- package/src/migrations/sql/20221019173729_settings.ts +70 -0
- package/src/migrations/sql/20221029103554_refactor_function_assignments.ts +41 -0
- package/src/migrations/sql/20221102190532_commands.ts +66 -0
- package/src/migrations/sql/20221203135001-builtin_modules.ts +56 -0
- package/src/migrations/sql/20230308183400-persistent-variables.ts +74 -0
- package/src/migrations/sql/20230314183400-auth-ory.ts +27 -0
- package/src/migrations/sql/20230325156123_command-arguments.ts +24 -0
- package/src/migrations/sql/20230407132022-module-descriptions.ts +13 -0
- package/src/migrations/sql/20230407143733-module-json-schema-config.ts +16 -0
- package/src/migrations/sql/20230407173055-hook-regex-optional.ts +13 -0
- package/src/migrations/sql/20230415154935-cronjob-configs.ts +18 -0
- package/src/migrations/sql/20230503132906-variables-extra-meta.ts +31 -0
- package/src/migrations/sql/20230604130951-fix-hook-eventtypes.ts +12 -0
- package/src/migrations/sql/20230617081049-discordId-for-users.ts +16 -0
- package/src/migrations/sql/20230618053611-discord-funtionality.ts +34 -0
- package/src/migrations/sql/20230622192402-discord-hooks.ts +20 -0
- package/src/migrations/sql/20230707081218-playerOnGameServerExtension.ts +21 -0
- package/src/migrations/sql/20230710174340-events.ts +21 -0
- package/src/migrations/sql/20230712061220-roles-permissions-extension.ts +50 -0
- package/src/migrations/sql/20230713184927-variables-modulescoped.ts +32 -0
- package/src/migrations/sql/20230714045136-domain-index.ts +40 -0
- package/src/migrations/sql/20230714045727-events-index.ts +19 -0
- package/src/migrations/sql/20230715102519-module-permissions-extra-fields.ts +38 -0
- package/src/migrations/sql/20230724062109-roles-constraints.ts +16 -0
- package/src/migrations/sql/20230811095701-userId-on-events.ts +14 -0
- package/src/migrations/sql/20230921123717-count-for-permissions.ts +101 -0
- package/src/migrations/sql/20231111102812-details-system-permissions.ts +192 -0
- package/src/migrations/sql/20231114151343-system-roles.ts +46 -0
- package/src/migrations/sql/20231118082301-add-new-permissions.ts +200 -0
- package/src/migrations/sql/20231119115037-timedRoles.ts +23 -0
- package/src/migrations/sql/20231123150854-economy-base.ts +15 -0
- package/src/migrations/sql/20231123171611-economy-settings.ts +15 -0
- package/src/migrations/sql/20231124140441-json-module-assignments.ts +29 -0
- package/src/migrations/sql/20231208114507-settings-refactor.ts +114 -0
- package/src/migrations/sql/20231208171234-game-items.ts +20 -0
- package/src/migrations/sql/20231216100720-player-inventory.ts +16 -0
- package/src/migrations/sql/20231222180438-steam-data.ts +27 -0
- package/src/migrations/sql/20231223132631-pog-online.ts +13 -0
- package/src/migrations/sql/20231223212031-unique-index-item-def.ts +27 -0
- package/src/migrations/sql/20231224135126-gameserver-online-status.ts +13 -0
- package/src/migrations/sql/20231224155226-unique-pog.ts +27 -0
- package/src/migrations/sql/20231225140650-extra-ip-info.ts +27 -0
- package/src/migrations/sql/20231227144315-unique-constraints-player.ts +74 -0
- package/src/migrations/sql/20231229144707-more-player-constraints.ts +20 -0
- package/src/migrations/sql/20240101162751-add-settings-constraint.ts +39 -0
- package/src/migrations/sql/20240105130846-remove-some-module-perms.ts +104 -0
- package/src/migrations/sql/20240116141936-add-ui-schema-to-module.ts +13 -0
- package/src/migrations/sql/20240119152426-remove-hook-check.ts +18 -0
- package/src/migrations/sql/20240121142329-move-ip-history.ts +53 -0
- package/src/migrations/sql/20240202101208-rename-economy-to-economyUtils.ts +15 -0
- package/src/migrations/sql/20240216120143-domain-state.ts +13 -0
- package/src/migrations/sql/20240229141340-looser-fks-events.ts +20 -0
- package/src/migrations/sql/20240301063505-module-functions.ts +17 -0
- package/src/migrations/util/alterEnum.ts +10 -0
- package/src/queryBuilder.ts +133 -0
- package/src/redis.ts +58 -0
- package/tsconfig.build.json +9 -0
- package/tsconfig.json +8 -0
- 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,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,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,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,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,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,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,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,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,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,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,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,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,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,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,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"}
|