diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/mastodon_api/mastodon_api_controller.ex | 52 | ||||
| -rw-r--r-- | lib/pleroma/web/router.ex | 5 | 
2 files changed, 57 insertions, 0 deletions
| diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex index a42f341c2..71f34a488 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -621,6 +621,58 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do      json(conn, %{})    end +  def search2(%{assigns: %{user: user}} = conn, %{"q" => query} = params) do +    accounts = User.search(query, params["resolve"] == "true") + +    fetched = +      if Regex.match?(~r/https?:/, query) do +        with {:ok, activities} <- OStatus.fetch_activity_from_url(query) do +          activities +          |> Enum.filter(fn +            %{data: %{"type" => "Create"}} -> true +            _ -> false +          end) +        else +          _e -> [] +        end +      end || [] + +    q = +      from( +        a in Activity, +        where: fragment("?->>'type' = 'Create'", a.data), +        where: "https://www.w3.org/ns/activitystreams#Public" in a.recipients, +        where: +          fragment( +            "to_tsvector('english', ?->'object'->>'content') @@ plainto_tsquery('english', ?)", +            a.data, +            ^query +          ), +        limit: 20, +        order_by: [desc: :id] +      ) + +    statuses = Repo.all(q) ++ fetched + +    tags_path = Web.base_url() <> "/tag/" + +    tags = +      String.split(query) +      |> Enum.uniq() +      |> Enum.filter(fn tag -> String.starts_with?(tag, "#") end) +      |> Enum.map(fn tag -> String.slice(tag, 1..-1) end) +      |> Enum.map(fn tag -> %{name: tag, url: tags_path <> tag} end) + +    res = %{ +      "accounts" => AccountView.render("accounts.json", users: accounts, for: user, as: :user), +      "statuses" => +        StatusView.render("index.json", activities: statuses, for: user, as: :activity), +      "hashtags" => tags +    } + +    json(conn, res) +  end +    def search(%{assigns: %{user: user}} = conn, %{"q" => query} = params) do      accounts = User.search(query, params["resolve"] == "true") diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 929a70f91..ebe68218b 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -175,6 +175,11 @@ defmodule Pleroma.Web.Router do      get("/search", MastodonAPIController, :search)    end +  scope "/api/v2", Pleroma.Web.MastodonAPI do +    pipe_through(:api) +    get("/search", MastodonAPIController, :search2) +  end +    scope "/api", Pleroma.Web do      pipe_through(:config) | 
