lemmy/migrations/2023-04-14-175955_add_listingtype_sorttype_enums/up.sql
Dessalines d8722b6e91
Adding diesel enums for SortType and ListingType (#2808)
* Adding diesel enums for SortType and ListingType

- Uses diesel-derive-enum.
- Adds diesel.toml , so we can again use the auto-generated schema.rs
- Fixes a lot of DB null issues and column ordering issues.
- Fixes #1136
- Also replaces RegistrationMode boilerplate.

* Fixing unit tests 1.

* Remove comment line.

* Before patch.

* Before again.

* Using patch file to fix diesel_ltree issue with diesel.toml

* Adding some yalc ignores

* Fixing RegistrationMode enums

* Adding woodpecker diesel schema check.

* Try adding openssl 1.

* Try using diesel-cli image 1

* Try using diesel-cli image 2

* Try using diesel-cli image 3

* Try using diesel-cli image 4

* Try using diesel-cli image 5

* Try using diesel-cli image 6

* Try using diesel-cli image 7

* Try using diesel-cli image 8

* Try using diesel-cli image 9

* Try using diesel-cli image 10

* Try using diesel-cli image 11

* Try using diesel-cli image 12

* Try using diesel-cli image 13
2023-04-17 15:19:51 -04:00

62 lines
2.8 KiB
SQL

-- A few DB fixes
alter table community alter column hidden set not null;
alter table community alter column posting_restricted_to_mods set not null;
alter table activity alter column sensitive set not null;
alter table mod_add alter column removed set not null;
alter table mod_add_community alter column removed set not null;
alter table mod_ban alter column banned set not null;
alter table mod_ban_from_community alter column banned set not null;
alter table mod_hide_community alter column hidden set not null;
alter table mod_lock_post alter column locked set not null;
alter table mod_remove_comment alter column removed set not null;
alter table mod_remove_community alter column removed set not null;
alter table mod_remove_post alter column removed set not null;
alter table mod_transfer_community drop column removed;
alter table language alter column code set not null;
alter table language alter column name set not null;
-- Fix the registration mode enums
ALTER TYPE registration_mode_enum RENAME VALUE 'closed' TO 'Closed';
ALTER TYPE registration_mode_enum RENAME VALUE 'require_application' TO 'RequireApplication';
ALTER TYPE registration_mode_enum RENAME VALUE 'open' TO 'Open';
-- Create the enums
CREATE TYPE sort_type_enum AS ENUM ('Active', 'Hot', 'New', 'Old', 'TopDay', 'TopWeek', 'TopMonth', 'TopYear', 'TopAll', 'MostComments', 'NewComments');
CREATE TYPE listing_type_enum AS ENUM ('All', 'Local', 'Subscribed');
-- Alter the local_user table
alter table local_user alter column default_sort_type drop default;
alter table local_user alter column default_sort_type type sort_type_enum using
case default_sort_type
when 0 then 'Active'
when 1 then 'Hot'
when 2 then 'New'
when 3 then 'Old'
when 4 then 'TopDay'
when 5 then 'TopWeek'
when 6 then 'TopMonth'
when 7 then 'TopYear'
when 8 then 'TopAll'
when 9 then 'MostComments'
when 10 then 'NewComments'
else 'Active'
end :: sort_type_enum;
alter table local_user alter column default_sort_type set default 'Active';
alter table local_user alter column default_listing_type drop default;
alter table local_user alter column default_listing_type type listing_type_enum using
case default_listing_type
when 0 then 'All'
when 1 then 'Local'
when 2 then 'Subscribed'
else 'Local'
end :: listing_type_enum;
alter table local_user alter column default_listing_type set default 'Local';
-- Alter the local site column
alter table local_site alter column default_post_listing_type drop default;
alter table local_site alter column default_post_listing_type type listing_type_enum using default_post_listing_type::listing_type_enum;
alter table local_site alter column default_post_listing_type set default 'Local';