diff options
Diffstat (limited to 'priv')
11 files changed, 440 insertions, 45 deletions
| diff --git a/priv/gettext/config_descriptions.pot b/priv/gettext/config_descriptions.pot index 9021fbfab..a8074ee64 100644 --- a/priv/gettext/config_descriptions.pot +++ b/priv/gettext/config_descriptions.pot @@ -1722,12 +1722,6 @@ msgstr ""  #, elixir-autogen, elixir-format  #: lib/pleroma/docs/translator.ex:5 -msgctxt "config description at :pleroma-:instance > :birthday_min_age" -msgid "Minimum required age for users to create account. Only used if birthday is required." -msgstr "" - -#, elixir-autogen, elixir-format -#: lib/pleroma/docs/translator.ex:5  msgctxt "config description at :pleroma-:instance > :birthday_required"  msgid "Require users to enter their birthday."  msgstr "" @@ -6021,3 +6015,45 @@ msgstr ""  msgctxt "config label at :pleroma-:instance > :short_description"  msgid "Short description"  msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config description at :pleroma-:delete_context_objects" +msgid "`delete_context_objects` background migration settings" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config description at :pleroma-:delete_context_objects > :fault_rate_allowance" +msgid "Max accepted rate of objects that failed in the migration. Any value from 0.0 which tolerates no errors to 1.0 which will enable the feature even if context object deletion failed for all records." +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config description at :pleroma-:delete_context_objects > :sleep_interval_ms" +msgid "Sleep interval between each chunk of processed records in order to decrease the load on the system (defaults to 0 and should be keep default on most instances)." +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config description at :pleroma-:instance > :birthday_min_age" +msgid "Minimum required age (in days) for users to create account. Only used if birthday is required." +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config label at :pleroma-:delete_context_objects" +msgid "Delete context objects" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config label at :pleroma-:delete_context_objects > :fault_rate_allowance" +msgid "Fault rate allowance" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/docs/translator.ex:5 +msgctxt "config label at :pleroma-:delete_context_objects > :sleep_interval_ms" +msgid "Sleep interval ms" +msgstr "" diff --git a/priv/gettext/errors.pot b/priv/gettext/errors.pot index 85854d23e..274e5fe7f 100644 --- a/priv/gettext/errors.pot +++ b/priv/gettext/errors.pot @@ -90,7 +90,7 @@ msgid "must be equal to %{number}"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api.ex:523 +#: lib/pleroma/web/common_api.ex:558  msgid "Account not found"  msgstr "" @@ -121,12 +121,12 @@ msgid "Can't get favorites"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:482 +#: lib/pleroma/web/common_api/utils.ex:457  msgid "Cannot post an empty status without attachments"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:441 +#: lib/pleroma/web/common_api/utils.ex:445  msgid "Comment must be up to %{max_size} characters"  msgstr "" @@ -157,13 +157,13 @@ msgid "Could not unrepeat"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api.ex:530 -#: lib/pleroma/web/common_api.ex:539 +#: lib/pleroma/web/common_api.ex:565 +#: lib/pleroma/web/common_api.ex:574  msgid "Could not update state"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/mastodon_api/controllers/timeline_controller.ex:205 +#: lib/pleroma/web/mastodon_api/controllers/timeline_controller.ex:207  msgid "Error."  msgstr "" @@ -194,7 +194,7 @@ msgid "Invalid parameters"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:349 +#: lib/pleroma/web/common_api/utils.ex:353  msgid "Invalid password."  msgstr "" @@ -214,11 +214,6 @@ msgid "Missing parameters"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:477 -msgid "No such conversation" -msgstr "" - -#, elixir-autogen, elixir-format  #: lib/pleroma/web/admin_api/controllers/admin_api_controller.ex:171  #: lib/pleroma/web/admin_api/controllers/admin_api_controller.ex:197  #: lib/pleroma/web/admin_api/controllers/admin_api_controller.ex:239 @@ -226,7 +221,7 @@ msgid "No such permission_group"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:515 +#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:502  #: lib/pleroma/web/admin_api/controllers/fallback_controller.ex:11  #: lib/pleroma/web/feed/tag_controller.ex:16  #: lib/pleroma/web/feed/user_controller.ex:69 @@ -245,7 +240,7 @@ msgstr ""  #: lib/pleroma/web/mastodon_api/controllers/poll_controller.ex:39  #: lib/pleroma/web/mastodon_api/controllers/poll_controller.ex:51  #: lib/pleroma/web/mastodon_api/controllers/poll_controller.ex:52 -#: lib/pleroma/web/mastodon_api/controllers/status_controller.ex:326 +#: lib/pleroma/web/mastodon_api/controllers/status_controller.ex:382  #: lib/pleroma/web/mastodon_api/controllers/subscription_controller.ex:71  msgid "Record not found"  msgstr "" @@ -264,7 +259,7 @@ msgid "The message visibility must be direct"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:492 +#: lib/pleroma/web/common_api/utils.ex:467  msgid "The status is over the character limit"  msgstr "" @@ -301,22 +296,22 @@ msgid "Your login is missing a confirmed e-mail address"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:403 +#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:390  msgid "can't read inbox of %{nickname} as %{as_nickname}"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:502 +#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:489  msgid "can't update outbox of %{nickname} as %{as_nickname}"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api.ex:475 +#: lib/pleroma/web/common_api.ex:510  msgid "conversation is already muted"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:521 +#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:508  msgid "error"  msgstr "" @@ -523,6 +518,7 @@ msgstr ""  #: lib/pleroma/web/pleroma_api/controllers/notification_controller.ex:6  #: lib/pleroma/web/pleroma_api/controllers/report_controller.ex:6  #: lib/pleroma/web/pleroma_api/controllers/scrobble_controller.ex:6 +#: lib/pleroma/web/pleroma_api/controllers/settings_controller.ex:6  #: lib/pleroma/web/pleroma_api/controllers/two_factor_authentication_controller.ex:7  #: lib/pleroma/web/pleroma_api/controllers/user_import_controller.ex:6  #: lib/pleroma/web/static_fe/static_fe_controller.ex:6 @@ -551,7 +547,7 @@ msgid "You can't revoke your own admin/moderator status."  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/web/mastodon_api/controllers/timeline_controller.ex:129 +#: lib/pleroma/web/mastodon_api/controllers/timeline_controller.ex:131  msgid "authorization required for timeline view"  msgstr "" @@ -572,29 +568,19 @@ msgid "User is not an admin."  msgstr ""  #, elixir-format -#: lib/pleroma/user/backup.ex:75 +#: lib/pleroma/user/backup.ex:73  msgid "Last export was less than a day ago"  msgid_plural "Last export was less than %{days} days ago"  msgstr[0] ""  msgstr[1] ""  #, elixir-autogen, elixir-format -#: lib/pleroma/user/backup.ex:93 -msgid "Backups require enabled email" -msgstr "" - -#, elixir-autogen, elixir-format -#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:434 +#: lib/pleroma/web/activity_pub/activity_pub_controller.ex:421  msgid "Character limit (%{limit} characters) exceeded, contains %{length} characters"  msgstr ""  #, elixir-autogen, elixir-format -#: lib/pleroma/user/backup.ex:98 -msgid "Email is required" -msgstr "" - -#, elixir-autogen, elixir-format -#: lib/pleroma/web/common_api/utils.ex:507 +#: lib/pleroma/web/common_api/utils.ex:482  msgid "Too many attachments"  msgstr "" diff --git a/priv/gettext/static_pages.pot b/priv/gettext/static_pages.pot index 8e1b1d9db..3c64f1a29 100644 --- a/priv/gettext/static_pages.pot +++ b/priv/gettext/static_pages.pot @@ -83,6 +83,7 @@ msgid "Account followed!"  msgstr ""  #, elixir-autogen, elixir-format +#: lib/pleroma/web/templates/twitter_api/util/status_interact.html.eex:7  #: lib/pleroma/web/templates/twitter_api/util/subscribe.html.eex:7  msgctxt "placeholder text for account id"  msgid "Your account ID, e.g. lain@quitter.se" @@ -511,3 +512,51 @@ msgstr ""  msgctxt "account archive email body - admin requested"  msgid "<p>Admin @%{admin_nickname} requested a full backup of your Pleroma account. It's ready for download:</p>\n<p><a href=\"%{download_url}\">%{download_url}</a></p>\n"  msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/twitter_api/controllers/util_controller.ex:123 +msgctxt "remote follow error message - unknown error" +msgid "Something went wrong." +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/twitter_api/controllers/util_controller.ex:67 +msgctxt "remote follow error message - user not found" +msgid "Could not find user" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/templates/twitter_api/util/status_interact.html.eex:8 +msgctxt "status interact authorization button" +msgid "Interact" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/templates/twitter_api/util/status_interact.html.eex:2 +msgctxt "status interact error" +msgid "Error: %{error}" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/twitter_api/controllers/util_controller.ex:95 +msgctxt "status interact error message - status not found" +msgid "Could not find status" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/twitter_api/controllers/util_controller.ex:144 +msgctxt "status interact error message - unknown error" +msgid "Something went wrong." +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/templates/twitter_api/util/status_interact.html.eex:4 +msgctxt "status interact header" +msgid "Interacting with %{nickname}'s %{status_link}" +msgstr "" + +#, elixir-autogen, elixir-format +#: lib/pleroma/web/templates/twitter_api/util/status_interact.html.eex:4 +msgctxt "status interact header - status link text" +msgid "status" +msgstr "" diff --git a/priv/repo/migrations/20220605185734_add_update_to_notifications_enum.exs b/priv/repo/migrations/20220605185734_add_update_to_notifications_enum.exs new file mode 100644 index 000000000..0656c885f --- /dev/null +++ b/priv/repo/migrations/20220605185734_add_update_to_notifications_enum.exs @@ -0,0 +1,51 @@ +defmodule Pleroma.Repo.Migrations.AddUpdateToNotificationsEnum do +  use Ecto.Migration + +  @disable_ddl_transaction true + +  def up do +    """ +    alter type notification_type add value 'update' +    """ +    |> execute() +  end + +  # 20210717000000_add_poll_to_notifications_enum.exs +  def down do +    alter table(:notifications) do +      modify(:type, :string) +    end + +    """ +    delete from notifications where type = 'update' +    """ +    |> 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', +      'pleroma:report', +      'poll' +    ) +    """ +    |> execute() + +    """ +    alter table notifications +    alter column type type notification_type using (type::notification_type) +    """ +    |> execute() +  end +end diff --git a/priv/repo/migrations/20220711182322_add_associated_object_id_function.exs b/priv/repo/migrations/20220711182322_add_associated_object_id_function.exs new file mode 100644 index 000000000..76348f31a --- /dev/null +++ b/priv/repo/migrations/20220711182322_add_associated_object_id_function.exs @@ -0,0 +1,37 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.AddAssociatedObjectIdFunction do +  use Ecto.Migration + +  def up do +    statement = """ +    CREATE OR REPLACE FUNCTION associated_object_id(data jsonb) RETURNS varchar AS $$ +    DECLARE +      object_data jsonb; +    BEGIN +      IF jsonb_typeof(data->'object') = 'array' THEN +        object_data := data->'object'->0; +      ELSE +        object_data := data->'object'; +      END IF; + +      IF jsonb_typeof(object_data->'id') = 'string' THEN +        RETURN object_data->>'id'; +      ELSIF jsonb_typeof(object_data) = 'string' THEN +        RETURN object_data#>>'{}'; +      ELSE +        RETURN NULL; +      END IF; +    END; +    $$ LANGUAGE plpgsql IMMUTABLE; +    """ + +    execute(statement) +  end + +  def down do +    execute("DROP FUNCTION IF EXISTS associated_object_id(data jsonb)") +  end +end diff --git a/priv/repo/migrations/20220711192750_switch_to_associated_object_id_index.exs b/priv/repo/migrations/20220711192750_switch_to_associated_object_id_index.exs new file mode 100644 index 000000000..75c1cd40b --- /dev/null +++ b/priv/repo/migrations/20220711192750_switch_to_associated_object_id_index.exs @@ -0,0 +1,37 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.SwitchToAssociatedObjectIdIndex do +  use Ecto.Migration +  @disable_ddl_transaction true +  @disable_migration_lock true + +  def up do +    drop_if_exists( +      index(:activities, ["(coalesce(data->'object'->>'id', data->>'object'))"], +        name: :activities_create_objects_index +      ) +    ) + +    create( +      index(:activities, ["associated_object_id(data)"], +        name: :activities_create_objects_index, +        concurrently: true +      ) +    ) +  end + +  def down do +    drop_if_exists( +      index(:activities, ["associated_object_id(data)"], name: :activities_create_objects_index) +    ) + +    create( +      index(:activities, ["(coalesce(data->'object'->>'id', data->>'object'))"], +        name: :activities_create_objects_index, +        concurrently: true +      ) +    ) +  end +end diff --git a/priv/repo/migrations/20220807125023_data_migration_delete_context_objects.exs b/priv/repo/migrations/20220807125023_data_migration_delete_context_objects.exs new file mode 100644 index 000000000..84365dbe3 --- /dev/null +++ b/priv/repo/migrations/20220807125023_data_migration_delete_context_objects.exs @@ -0,0 +1,18 @@ +defmodule Pleroma.Repo.Migrations.DataMigrationDeleteContextObjects do +  use Ecto.Migration + +  require Logger + +  def up do +    dt = NaiveDateTime.utc_now() + +    execute( +      "INSERT INTO data_migrations(name, inserted_at, updated_at) " <> +        "VALUES ('delete_context_objects', '#{dt}', '#{dt}') ON CONFLICT DO NOTHING;" +    ) +  end + +  def down do +    execute("DELETE FROM data_migrations WHERE name = 'delete_context_objects';") +  end +end diff --git a/priv/repo/migrations/20220821004840_change_thread_visibility_to_use_new_object_id_index.exs b/priv/repo/migrations/20220821004840_change_thread_visibility_to_use_new_object_id_index.exs new file mode 100644 index 000000000..bb56843cb --- /dev/null +++ b/priv/repo/migrations/20220821004840_change_thread_visibility_to_use_new_object_id_index.exs @@ -0,0 +1,156 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.ChangeThreadVisibilityToUseNewObjectIdIndex do +  use Ecto.Migration + +  def up do +    execute(update_thread_visibility()) +  end + +  def down do +    execute(restore_thread_visibility()) +  end + +  def update_thread_visibility do +    """ +    CREATE OR REPLACE FUNCTION thread_visibility(actor varchar, activity_id varchar, local_public varchar default '') RETURNS boolean AS $$ +    DECLARE +      public varchar := 'https://www.w3.org/ns/activitystreams#Public'; +      child objects%ROWTYPE; +      activity activities%ROWTYPE; +      author_fa varchar; +      valid_recipients varchar[]; +      actor_user_following varchar[]; +    BEGIN +      --- Fetch actor following +      SELECT array_agg(following.follower_address) INTO actor_user_following FROM following_relationships +      JOIN users ON users.id = following_relationships.follower_id +      JOIN users AS following ON following.id = following_relationships.following_id +      WHERE users.ap_id = actor; + +      --- Fetch our initial activity. +      SELECT * INTO activity FROM activities WHERE activities.data->>'id' = activity_id; + +      LOOP +        --- Ensure that we have an activity before continuing. +        --- If we don't, the thread is not satisfiable. +        IF activity IS NULL THEN +          RETURN false; +        END IF; + +        --- We only care about Create activities. +        IF activity.data->>'type' != 'Create' THEN +          RETURN true; +        END IF; + +        --- Normalize the child object into child. +        SELECT * INTO child FROM objects +        INNER JOIN activities ON associated_object_id(activities.data) = objects.data->>'id' +        WHERE associated_object_id(activity.data) = objects.data->>'id'; + +        --- Fetch the author's AS2 following collection. +        SELECT COALESCE(users.follower_address, '') INTO author_fa FROM users WHERE users.ap_id = activity.actor; + +        --- Prepare valid recipients array. +        valid_recipients := ARRAY[actor, public]; +        --- If we specified local public, add it. +        IF local_public <> '' THEN +          valid_recipients := valid_recipients || local_public; +        END IF; +        IF ARRAY[author_fa] && actor_user_following THEN +          valid_recipients := valid_recipients || author_fa; +        END IF; + +        --- Check visibility. +        IF NOT valid_recipients && activity.recipients THEN +          --- activity not visible, break out of the loop +          RETURN false; +        END IF; + +        --- If there's a parent, load it and do this all over again. +        IF (child.data->'inReplyTo' IS NOT NULL) AND (child.data->'inReplyTo' != 'null'::jsonb) THEN +          SELECT * INTO activity FROM activities +          INNER JOIN objects ON associated_object_id(activities.data) = objects.data->>'id' +          WHERE child.data->>'inReplyTo' = objects.data->>'id'; +        ELSE +          RETURN true; +        END IF; +      END LOOP; +    END; +    $$ LANGUAGE plpgsql IMMUTABLE; +    """ +  end + +  # priv/repo/migrations/20220509180452_change_thread_visibility_to_be_local_only_aware.exs +  def restore_thread_visibility do +    """ +    CREATE OR REPLACE FUNCTION thread_visibility(actor varchar, activity_id varchar, local_public varchar default '') RETURNS boolean AS $$ +    DECLARE +      public varchar := 'https://www.w3.org/ns/activitystreams#Public'; +      child objects%ROWTYPE; +      activity activities%ROWTYPE; +      author_fa varchar; +      valid_recipients varchar[]; +      actor_user_following varchar[]; +    BEGIN +      --- Fetch actor following +      SELECT array_agg(following.follower_address) INTO actor_user_following FROM following_relationships +      JOIN users ON users.id = following_relationships.follower_id +      JOIN users AS following ON following.id = following_relationships.following_id +      WHERE users.ap_id = actor; + +      --- Fetch our initial activity. +      SELECT * INTO activity FROM activities WHERE activities.data->>'id' = activity_id; + +      LOOP +        --- Ensure that we have an activity before continuing. +        --- If we don't, the thread is not satisfiable. +        IF activity IS NULL THEN +          RETURN false; +        END IF; + +        --- We only care about Create activities. +        IF activity.data->>'type' != 'Create' THEN +          RETURN true; +        END IF; + +        --- Normalize the child object into child. +        SELECT * INTO child FROM objects +        INNER JOIN activities ON COALESCE(activities.data->'object'->>'id', activities.data->>'object') = objects.data->>'id' +        WHERE COALESCE(activity.data->'object'->>'id', activity.data->>'object') = objects.data->>'id'; + +        --- Fetch the author's AS2 following collection. +        SELECT COALESCE(users.follower_address, '') INTO author_fa FROM users WHERE users.ap_id = activity.actor; + +        --- Prepare valid recipients array. +        valid_recipients := ARRAY[actor, public]; +        --- If we specified local public, add it. +        IF local_public <> '' THEN +          valid_recipients := valid_recipients || local_public; +        END IF; +        IF ARRAY[author_fa] && actor_user_following THEN +          valid_recipients := valid_recipients || author_fa; +        END IF; + +        --- Check visibility. +        IF NOT valid_recipients && activity.recipients THEN +          --- activity not visible, break out of the loop +          RETURN false; +        END IF; + +        --- If there's a parent, load it and do this all over again. +        IF (child.data->'inReplyTo' IS NOT NULL) AND (child.data->'inReplyTo' != 'null'::jsonb) THEN +          SELECT * INTO activity FROM activities +          INNER JOIN objects ON COALESCE(activities.data->'object'->>'id', activities.data->>'object') = objects.data->>'id' +          WHERE child.data->>'inReplyTo' = objects.data->>'id'; +        ELSE +          RETURN true; +        END IF; +      END LOOP; +    END; +    $$ LANGUAGE plpgsql IMMUTABLE; +    """ +  end +end diff --git a/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs b/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs new file mode 100644 index 000000000..43bc7100b --- /dev/null +++ b/priv/repo/migrations/20220905011454_generate_unset_user_keys.exs @@ -0,0 +1,28 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Repo.Migrations.GenerateUnsetUserKeys do +  use Ecto.Migration +  import Ecto.Query +  alias Pleroma.Keys +  alias Pleroma.Repo +  alias Pleroma.User + +  def change do +    query = +      from(u in User, +        where: u.local == true, +        where: is_nil(u.keys), +        select: u +      ) + +    Repo.stream(query) +    |> Enum.each(fn user -> +      with {:ok, pem} <- Keys.generate_rsa_pem() do +        Ecto.Changeset.cast(user, %{keys: pem}, [:keys]) +        |> Repo.update() +      end +    end) +  end +end diff --git a/priv/static/schemas/litepub-0.1.jsonld b/priv/static/schemas/litepub-0.1.jsonld index 946099a6e..650118475 100644 --- a/priv/static/schemas/litepub-0.1.jsonld +++ b/priv/static/schemas/litepub-0.1.jsonld @@ -36,7 +36,8 @@                  "@id": "as:alsoKnownAs",                  "@type": "@id"              }, -            "vcard": "http://www.w3.org/2006/vcard/ns#" +            "vcard": "http://www.w3.org/2006/vcard/ns#", +            "formerRepresentations": "litepub:formerRepresentations"          }      ]  } diff --git a/priv/templates/sample_config.eex b/priv/templates/sample_config.eex index 0068969ac..d44c324ca 100644 --- a/priv/templates/sample_config.eex +++ b/priv/templates/sample_config.eex @@ -3,11 +3,7 @@  # NOTE: This file should not be committed to a repo or otherwise made public  # without removing sensitive information. -<%= if Code.ensure_loaded?(Config) or not Code.ensure_loaded?(Mix.Config) do -  "import Config" -else -  "use Mix.Config" -end %> +import Config  config :pleroma, Pleroma.Web.Endpoint,     url: [host: "<%= domain %>", scheme: "https", port: <%= port %>], | 
