diff options
| author | lain <lain@soykaf.club> | 2020-06-23 10:54:15 +0000 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2020-06-23 10:54:15 +0000 | 
| commit | b7f297f0bd214416f3faded4a6221899b68edabd (patch) | |
| tree | faffc6a136069436c3e2b77288057f4fde7b99ee /lib | |
| parent | 59e2a1018a56a8390bd059e2bfae0d6cb6ccc63a (diff) | |
| parent | 84aa9c78dd314e93a5153e3584af38b8c218caed (diff) | |
| download | pleroma-b7f297f0bd214416f3faded4a6221899b68edabd.tar.gz pleroma-b7f297f0bd214416f3faded4a6221899b68edabd.zip | |
Merge branch 'issue/1798' into 'develop'
[#1798] fixed migration the settings to DB
See merge request pleroma/pleroma!2655
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/mix/tasks/pleroma/config.ex | 1 | ||||
| -rw-r--r-- | lib/pleroma/application.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/application_requirements.ex | 107 | ||||
| -rw-r--r-- | lib/pleroma/repo.ex | 37 | 
4 files changed, 110 insertions, 37 deletions
| diff --git a/lib/mix/tasks/pleroma/config.ex b/lib/mix/tasks/pleroma/config.ex index f1b3a8766..d5129d410 100644 --- a/lib/mix/tasks/pleroma/config.ex +++ b/lib/mix/tasks/pleroma/config.ex @@ -52,6 +52,7 @@ defmodule Mix.Tasks.Pleroma.Config do    defp do_migrate_to_db(config_file) do      if File.exists?(config_file) do +      shell_info("Migrating settings from file: #{Path.expand(config_file)}")        Ecto.Adapters.SQL.query!(Repo, "TRUNCATE config;")        Ecto.Adapters.SQL.query!(Repo, "ALTER SEQUENCE config_id_seq RESTART;") diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index 4a21bf138..9615af122 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -39,7 +39,7 @@ defmodule Pleroma.Application do      Pleroma.HTML.compile_scrubbers()      Config.DeprecationWarnings.warn()      Pleroma.Plugs.HTTPSecurityPlug.warn_if_disabled() -    Pleroma.Repo.check_migrations_applied!() +    Pleroma.ApplicationRequirements.verify!()      setup_instrumenters()      load_custom_modules() diff --git a/lib/pleroma/application_requirements.ex b/lib/pleroma/application_requirements.ex new file mode 100644 index 000000000..88575a498 --- /dev/null +++ b/lib/pleroma/application_requirements.ex @@ -0,0 +1,107 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.ApplicationRequirements do +  @moduledoc """ +  The module represents the collection of validations to runs before start server. +  """ + +  defmodule VerifyError, do: defexception([:message]) + +  import Ecto.Query + +  require Logger + +  @spec verify!() :: :ok | VerifyError.t() +  def verify! do +    :ok +    |> check_migrations_applied!() +    |> check_rum!() +    |> handle_result() +  end + +  defp handle_result(:ok), do: :ok +  defp handle_result({:error, message}), do: raise(VerifyError, message: message) + +  # Checks for pending migrations. +  # +  def check_migrations_applied!(:ok) do +    unless Pleroma.Config.get( +             [:i_am_aware_this_may_cause_data_loss, :disable_migration_check], +             false +           ) do +      {_, res, _} = +        Ecto.Migrator.with_repo(Pleroma.Repo, fn repo -> +          down_migrations = +            Ecto.Migrator.migrations(repo) +            |> Enum.reject(fn +              {:up, _, _} -> true +              {:down, _, _} -> false +            end) + +          if length(down_migrations) > 0 do +            down_migrations_text = +              Enum.map(down_migrations, fn {:down, id, name} -> "- #{name} (#{id})\n" end) + +            Logger.error( +              "The following migrations were not applied:\n#{down_migrations_text}If you want to start Pleroma anyway, set\nconfig :pleroma, :i_am_aware_this_may_cause_data_loss, disable_migration_check: true" +            ) + +            {:error, "Unapplied Migrations detected"} +          else +            :ok +          end +        end) + +      res +    else +      :ok +    end +  end + +  def check_migrations_applied!(result), do: result + +  # Checks for settings of RUM indexes. +  # +  defp check_rum!(:ok) do +    {_, res, _} = +      Ecto.Migrator.with_repo(Pleroma.Repo, fn repo -> +        migrate = +          from(o in "columns", +            where: o.table_name == "objects", +            where: o.column_name == "fts_content" +          ) +          |> repo.exists?(prefix: "information_schema") + +        setting = Pleroma.Config.get([:database, :rum_enabled], false) + +        do_check_rum!(setting, migrate) +      end) + +    res +  end + +  defp check_rum!(result), do: result + +  defp do_check_rum!(setting, migrate) do +    case {setting, migrate} do +      {true, false} -> +        Logger.error( +          "Use `RUM` index is enabled, but were not applied migrations for it.\nIf you want to start Pleroma anyway, set\nconfig :pleroma, :database, rum_enabled: false\nOtherwise apply the following migrations:\n`mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/`" +        ) + +        {:error, "Unapplied RUM Migrations detected"} + +      {false, true} -> +        Logger.error( +          "Detected applied migrations to use `RUM` index, but `RUM` isn't enable in settings.\nIf you want to use `RUM`, set\nconfig :pleroma, :database, rum_enabled: true\nOtherwise roll `RUM` migrations back.\n`mix ecto.rollback --migrations-path priv/repo/optional_migrations/rum_indexing/`" +        ) + +        {:error, "RUM Migrations detected"} + +      _ -> +        :ok +    end +  end +end diff --git a/lib/pleroma/repo.ex b/lib/pleroma/repo.ex index 6d85d70bc..f317e4d58 100644 --- a/lib/pleroma/repo.ex +++ b/lib/pleroma/repo.ex @@ -11,9 +11,7 @@ defmodule Pleroma.Repo do    import Ecto.Query    require Logger -  defmodule Instrumenter do -    use Prometheus.EctoInstrumenter -  end +  defmodule Instrumenter, do: use(Prometheus.EctoInstrumenter)    @doc """    Dynamically loads the repository url from the @@ -51,35 +49,6 @@ defmodule Pleroma.Repo do      end    end -  def check_migrations_applied!() do -    unless Pleroma.Config.get( -             [:i_am_aware_this_may_cause_data_loss, :disable_migration_check], -             false -           ) do -      Ecto.Migrator.with_repo(__MODULE__, fn repo -> -        down_migrations = -          Ecto.Migrator.migrations(repo) -          |> Enum.reject(fn -            {:up, _, _} -> true -            {:down, _, _} -> false -          end) - -        if length(down_migrations) > 0 do -          down_migrations_text = -            Enum.map(down_migrations, fn {:down, id, name} -> "- #{name} (#{id})\n" end) - -          Logger.error( -            "The following migrations were not applied:\n#{down_migrations_text}If you want to start Pleroma anyway, set\nconfig :pleroma, :i_am_aware_this_may_cause_data_loss, disable_migration_check: true" -          ) - -          raise Pleroma.Repo.UnappliedMigrationsError -        end -      end) -    else -      :ok -    end -  end -    def chunk_stream(query, chunk_size) do      # We don't actually need start and end funcitons of resource streaming,      # but it seems to be the only way to not fetch records one-by-one and @@ -107,7 +76,3 @@ defmodule Pleroma.Repo do      )    end  end - -defmodule Pleroma.Repo.UnappliedMigrationsError do -  defexception message: "Unapplied Migrations detected" -end | 
