aboutsummaryrefslogtreecommitdiff
path: root/src/api/database/migrations/20201227023216_addUniques.js
diff options
context:
space:
mode:
authorPitu <[email protected]>2020-12-27 03:02:14 +0900
committerPitu <[email protected]>2020-12-27 03:02:14 +0900
commit68634418e1c86d5ebd5dc2feead241919d3aa9ed (patch)
treebd07175599458add579dee83934f49bbdf2cda21 /src/api/database/migrations/20201227023216_addUniques.js
parentchore: use instance name for album download (diff)
downloadhost.fuwn.me-68634418e1c86d5ebd5dc2feead241919d3aa9ed.tar.xz
host.fuwn.me-68634418e1c86d5ebd5dc2feead241919d3aa9ed.zip
Squashed commit of the following:
commit df4b0378571708086a276e49ac8630095e08b0b7 Author: Pitu <[email protected]> Date: Sun Dec 27 03:00:17 2020 +0900 feat: move database modification to a new migration file
Diffstat (limited to 'src/api/database/migrations/20201227023216_addUniques.js')
-rw-r--r--src/api/database/migrations/20201227023216_addUniques.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/api/database/migrations/20201227023216_addUniques.js b/src/api/database/migrations/20201227023216_addUniques.js
new file mode 100644
index 0000000..14f9e7f
--- /dev/null
+++ b/src/api/database/migrations/20201227023216_addUniques.js
@@ -0,0 +1,33 @@
+exports.up = async knex => {
+ await knex.schema.alterTable('users', table => {
+ table.unique(['username', 'apiKey']);
+ });
+
+ await knex.schema.alterTable('albums', table => {
+ table.boolean('nsfw').defaultTo(false);
+ table.unique(['userId', 'name']);
+ });
+
+ await knex.schema.alterTable('links', table => {
+ table.unique(['userId', 'albumId', 'identifier']);
+ });
+
+ await knex.schema.alterTable('albumsFiles', table => {
+ table.unique(['albumId', 'fileId']);
+ });
+
+ await knex.schema.alterTable('albumsLinks', table => {
+ table.unique(['linkId']);
+ });
+
+ await knex.schema.alterTable('tags', table => {
+ table.unique(['userId', 'name']);
+ });
+
+ await knex.schema.alterTable('fileTags', table => {
+ table.unique(['fileId', 'tagId']);
+ });
+};
+exports.down = async knex => {
+ // Nothing
+};