diff options
Diffstat (limited to 'priv/repo/migrations')
4 files changed, 102 insertions, 0 deletions
diff --git a/priv/repo/migrations/20200831152600_add_pleroma_report_to_enum_for_notifications.exs b/priv/repo/migrations/20200831152600_add_pleroma_report_to_enum_for_notifications.exs new file mode 100644 index 000000000..01fb90459 --- /dev/null +++ b/priv/repo/migrations/20200831152600_add_pleroma_report_to_enum_for_notifications.exs @@ -0,0 +1,48 @@ +defmodule Pleroma.Repo.Migrations.AddPleromaReportTypeToEnumForNotifications do +  use Ecto.Migration + +  @disable_ddl_transaction true + +  def up do +    """ +    alter type notification_type add value 'pleroma:report' +    """ +    |> execute() +  end + +  def down do +    alter table(:notifications) do +      modify(:type, :string) +    end + +    """ +    delete from notifications where type = 'pleroma:report' +    """ +    |> execute() + +    """ +    drop type if exists notification_type +    """ +    |> execute() + +    """ +    create type notification_type as enum ( +      'follow', +      'follow_request', +      'mention', +      'move', +      'pleroma:emoji_reaction', +      'pleroma:chat_mention', +      'reblog', +      'favourite' +    ) +    """ +    |> execute() + +    """ +    alter table notifications  +    alter column type type notification_type using (type::notification_type) +    """ +    |> execute() +  end +end diff --git a/priv/repo/migrations/20200915095704_remove_background_jobs.exs b/priv/repo/migrations/20200915095704_remove_background_jobs.exs new file mode 100644 index 000000000..9785bfb8a --- /dev/null +++ b/priv/repo/migrations/20200915095704_remove_background_jobs.exs @@ -0,0 +1,22 @@ +defmodule Pleroma.Repo.Migrations.RemoveBackgroundJobs do +  use Ecto.Migration + +  import Ecto.Query, only: [from: 2] + +  def up do +    from(j in "oban_jobs", +      where: +        j.queue == ^"background" and +          fragment("?->>'op'", j.args) in ^[ +            "fetch_data_for_activity", +            "media_proxy_prefetch", +            "media_proxy_preload" +          ] and +          j.worker == ^"Pleroma.Workers.BackgroundWorker", +      select: [:id] +    ) +    |> Pleroma.Repo.delete_all() +  end + +  def down, do: :ok +end diff --git a/priv/repo/migrations/20201113060459_remove_purge_expired_activity_worker_from_oban_config.exs b/priv/repo/migrations/20201113060459_remove_purge_expired_activity_worker_from_oban_config.exs new file mode 100644 index 000000000..fe31f4442 --- /dev/null +++ b/priv/repo/migrations/20201113060459_remove_purge_expired_activity_worker_from_oban_config.exs @@ -0,0 +1,19 @@ +defmodule Pleroma.Repo.Migrations.RemovePurgeExpiredActivityWorkerFromObanConfig do +  use Ecto.Migration + +  def change do +    with %Pleroma.ConfigDB{} = config <- +           Pleroma.ConfigDB.get_by_params(%{group: :pleroma, key: Oban}), +         crontab when is_list(crontab) <- config.value[:crontab], +         index when is_integer(index) <- +           Enum.find_index(crontab, fn {_, worker} -> +             worker == Pleroma.Workers.Cron.PurgeExpiredActivitiesWorker +           end) do +      updated_value = Keyword.put(config.value, :crontab, List.delete_at(crontab, index)) + +      config +      |> Ecto.Changeset.change(value: updated_value) +      |> Pleroma.Repo.update() +    end +  end +end diff --git a/priv/repo/migrations/20201217172858_data_migration_prolong_o_auth_tokens_valid_until.exs b/priv/repo/migrations/20201217172858_data_migration_prolong_o_auth_tokens_valid_until.exs new file mode 100644 index 000000000..560cc7447 --- /dev/null +++ b/priv/repo/migrations/20201217172858_data_migration_prolong_o_auth_tokens_valid_until.exs @@ -0,0 +1,13 @@ +defmodule Pleroma.Repo.Migrations.DataMigrationProlongOAuthTokensValidUntil do +  use Ecto.Migration + +  def up do +    expires_in = Pleroma.Config.get!([:oauth2, :token_expires_in]) +    valid_until = NaiveDateTime.add(NaiveDateTime.utc_now(), expires_in, :second) +    execute("update oauth_tokens set valid_until = '#{valid_until}'") +  end + +  def down do +    :noop +  end +end  | 
