diff options
author | lain <lain@soykaf.club> | 2023-06-11 11:02:39 +0000 |
---|---|---|
committer | lain <lain@soykaf.club> | 2023-06-11 11:02:39 +0000 |
commit | 1db29f734f7f12a49ab946ea467b07bf27bdce6d (patch) | |
tree | 589a9e5de87bf652c5557a653c78ca833ef520a9 /lib | |
parent | b762a7503cc7179cb452e38fa48199802b539fc7 (diff) | |
parent | a5066bb0789e15d808e99e8676c16ad74290419c (diff) | |
download | pleroma-1db29f734f7f12a49ab946ea467b07bf27bdce6d.tar.gz pleroma-1db29f734f7f12a49ab946ea467b07bf27bdce6d.zip |
Merge branch 'fep-fffd-url' into 'develop'
CommonFields: Use BareUri for :url
Closes #3121
See merge request pleroma/pleroma!3884
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/ecto_type/activity_pub/object_validators/bare_uri.ex | 23 | ||||
-rw-r--r-- | lib/pleroma/web/activity_pub/object_validators/common_fields.ex | 2 |
2 files changed, 24 insertions, 1 deletions
diff --git a/lib/pleroma/ecto_type/activity_pub/object_validators/bare_uri.ex b/lib/pleroma/ecto_type/activity_pub/object_validators/bare_uri.ex new file mode 100644 index 000000000..1038296e7 --- /dev/null +++ b/lib/pleroma/ecto_type/activity_pub/object_validators/bare_uri.ex @@ -0,0 +1,23 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2023 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.EctoType.ActivityPub.ObjectValidators.BareUri do + use Ecto.Type + + def type, do: :string + + def cast(uri) when is_binary(uri) do + case URI.parse(uri) do + %URI{scheme: nil} -> :error + %URI{} -> {:ok, uri} + _ -> :error + end + end + + def cast(_), do: :error + + def dump(data), do: {:ok, data} + + def load(data), do: {:ok, data} +end diff --git a/lib/pleroma/web/activity_pub/object_validators/common_fields.ex b/lib/pleroma/web/activity_pub/object_validators/common_fields.ex index 7b60c139a..d580208df 100644 --- a/lib/pleroma/web/activity_pub/object_validators/common_fields.ex +++ b/lib/pleroma/web/activity_pub/object_validators/common_fields.ex @@ -58,7 +58,7 @@ defmodule Pleroma.Web.ActivityPub.ObjectValidators.CommonFields do field(:like_count, :integer, default: 0) field(:announcement_count, :integer, default: 0) field(:inReplyTo, ObjectValidators.ObjectID) - field(:url, ObjectValidators.Uri) + field(:url, ObjectValidators.BareUri) field(:likes, {:array, ObjectValidators.ObjectID}, default: []) field(:announcements, {:array, ObjectValidators.ObjectID}, default: []) |