summaryrefslogtreecommitdiff
path: root/priv/repo/migrations/20190711042021_create_safe_jsonb_set.exs
blob: 2f336a5e84659b98d04dea60ce43b62cbb2ada28 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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