diff options
| author | rinpatch <rinpatch@sdf.org> | 2019-10-18 11:49:27 +0000 |
|---|---|---|
| committer | rinpatch <rinpatch@sdf.org> | 2019-10-18 11:49:27 +0000 |
| commit | deee9f31968c48fb15b4d6b93254d28232e54a69 (patch) | |
| tree | d53c7d132a53d2b510c5ac6403fb7cbdb1cf79d6 /priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs | |
| parent | c00797d08ef3e6c57250c9f013b6f912292b031b (diff) | |
| parent | 41c47639e3eae5d5e2840e9a9bb51cd99660af91 (diff) | |
| download | pleroma-deee9f31968c48fb15b4d6b93254d28232e54a69.tar.gz pleroma-deee9f31968c48fb15b4d6b93254d28232e54a69.zip | |
Merge branch 'bugfix/jsonb-set-fuckup' into 'release/1.1.1'
Fix a migration wiping user info of users that don't have any mutes
See merge request pleroma/pleroma!1856
Diffstat (limited to 'priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs')
| -rw-r--r-- | priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs b/priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs new file mode 100644 index 000000000..d70961431 --- /dev/null +++ b/priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs @@ -0,0 +1,22 @@ +defmodule Pleroma.Repo.Migrations.CreateSafeJsonbSet do + use Ecto.Migration + alias Pleroma.User + + def change do + execute(""" + create or replace function safe_jsonb_set(target jsonb, path text[], new_value jsonb, create_missing boolean default true) returns jsonb as $$ + declare + result jsonb; + begin + result := jsonb_set(target, path, coalesce(new_value, 'null'::jsonb), create_missing); + if result is NULL then + raise 'jsonb_set tried to wipe the object, please report this incindent to Pleroma bug tracker. https://git.pleroma.social/pleroma/pleroma/issues/new'; + return target; + else + return result; + end if; + end; + $$ language plpgsql; + """) + end +end |
