mirror of
https://github.com/plausible/analytics.git
synced 2024-12-29 04:22:34 +03:00
71ef0bd043
* Clean up after V2 migration This PR removes all the leftovers and alternative code branching after v2 migration. The self-hosted release is being drafted at: https://github.com/plausible/hosting/issues/68 Refs: - https://github.com/plausible/analytics/pull/2865 - https://github.com/plausible/analytics/pull/2825 - https://github.com/plausible/analytics/pull/2780 * !fixup
169 lines
4.9 KiB
Elixir
169 lines
4.9 KiB
Elixir
defmodule PlausibleWeb.Api.ExternalSitesController do
|
|
use PlausibleWeb, :controller
|
|
use Plausible.Repo
|
|
use Plug.ErrorHandler
|
|
alias Plausible.Sites
|
|
alias Plausible.Goals
|
|
alias PlausibleWeb.Api.Helpers, as: H
|
|
|
|
def create_site(conn, params) do
|
|
user = conn.assigns[:current_user]
|
|
|
|
case Sites.create(user, params) do
|
|
{:ok, %{site: site}} ->
|
|
json(conn, site)
|
|
|
|
{:error, :limit, limit, _} ->
|
|
conn
|
|
|> put_status(403)
|
|
|> json(%{
|
|
error:
|
|
"Your account has reached the limit of #{limit} sites per account. Please contact hello@plausible.io to unlock more sites."
|
|
})
|
|
|
|
{:error, _, changeset, _} ->
|
|
conn
|
|
|> put_status(400)
|
|
|> json(serialize_errors(changeset))
|
|
end
|
|
end
|
|
|
|
def get_site(conn, %{"site_id" => site_id}) do
|
|
site = Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner, :admin])
|
|
|
|
if site do
|
|
json(conn, site)
|
|
else
|
|
H.not_found(conn, "Site could not be found")
|
|
end
|
|
end
|
|
|
|
def delete_site(conn, %{"site_id" => site_id}) do
|
|
site = Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner])
|
|
|
|
if site do
|
|
{:ok, _} = Plausible.Site.Removal.run(site.domain)
|
|
json(conn, %{"deleted" => true})
|
|
else
|
|
H.not_found(conn, "Site could not be found")
|
|
end
|
|
end
|
|
|
|
def update_site(conn, %{"site_id" => site_id} = params) do
|
|
# for now this only allows to change the domain
|
|
site = Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner, :admin])
|
|
|
|
if site do
|
|
case Plausible.Site.Domain.change(site, params["domain"]) do
|
|
{:ok, site} ->
|
|
json(conn, site)
|
|
|
|
{:error, changeset} ->
|
|
conn
|
|
|> put_status(400)
|
|
|> json(serialize_errors(changeset))
|
|
end
|
|
else
|
|
H.not_found(conn, "Site could not be found")
|
|
end
|
|
end
|
|
|
|
defp expect_param_key(params, key) do
|
|
case Map.fetch(params, key) do
|
|
:error -> {:missing, key}
|
|
res -> res
|
|
end
|
|
end
|
|
|
|
def find_or_create_shared_link(conn, params) do
|
|
with {:ok, site_id} <- expect_param_key(params, "site_id"),
|
|
{:ok, link_name} <- expect_param_key(params, "name"),
|
|
site when not is_nil(site) <-
|
|
Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner, :admin]) do
|
|
shared_link = Repo.get_by(Plausible.Site.SharedLink, site_id: site.id, name: link_name)
|
|
|
|
shared_link =
|
|
case shared_link do
|
|
nil -> Sites.create_shared_link(site, link_name)
|
|
link -> {:ok, link}
|
|
end
|
|
|
|
case shared_link do
|
|
{:ok, link} ->
|
|
json(conn, %{
|
|
name: link.name,
|
|
url: Sites.shared_link_url(site, link)
|
|
})
|
|
end
|
|
else
|
|
nil ->
|
|
H.not_found(conn, "Site could not be found")
|
|
|
|
{:missing, "site_id"} ->
|
|
H.bad_request(conn, "Parameter `site_id` is required to create a shared link")
|
|
|
|
{:missing, "name"} ->
|
|
H.bad_request(conn, "Parameter `name` is required to create a shared link")
|
|
|
|
e ->
|
|
H.bad_request(conn, "Something went wrong: #{inspect(e)}")
|
|
end
|
|
end
|
|
|
|
def find_or_create_goal(conn, params) do
|
|
with {:ok, site_id} <- expect_param_key(params, "site_id"),
|
|
{:ok, _} <- expect_param_key(params, "goal_type"),
|
|
site when not is_nil(site) <-
|
|
Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner, :admin]),
|
|
{:ok, goal} <- Goals.find_or_create(site, params) do
|
|
json(conn, goal)
|
|
else
|
|
nil ->
|
|
H.not_found(conn, "Site could not be found")
|
|
|
|
{:missing, param} ->
|
|
H.bad_request(conn, "Parameter `#{param}` is required to create a goal")
|
|
|
|
e ->
|
|
H.bad_request(conn, "Something went wrong: #{inspect(e)}")
|
|
end
|
|
end
|
|
|
|
def delete_goal(conn, params) do
|
|
with {:ok, site_id} <- expect_param_key(params, "site_id"),
|
|
{:ok, goal_id} <- expect_param_key(params, "goal_id"),
|
|
site when not is_nil(site) <-
|
|
Sites.get_for_user(conn.assigns[:current_user].id, site_id, [:owner, :admin]) do
|
|
case Goals.delete(goal_id, site) do
|
|
:ok ->
|
|
json(conn, %{"deleted" => true})
|
|
|
|
{:error, :not_found} ->
|
|
H.not_found(conn, "Goal could not be found")
|
|
end
|
|
else
|
|
nil ->
|
|
H.not_found(conn, "Site could not be found")
|
|
|
|
{:missing, "site_id"} ->
|
|
H.bad_request(conn, "Parameter `site_id` is required to delete a goal")
|
|
|
|
{:missing, "goal_id"} ->
|
|
H.bad_request(conn, "Parameter `goal_id` is required to delete a goal")
|
|
|
|
e ->
|
|
H.bad_request(conn, "Something went wrong: #{inspect(e)}")
|
|
end
|
|
end
|
|
|
|
defp serialize_errors(changeset) do
|
|
{field, {msg, _opts}} = List.first(changeset.errors)
|
|
error_msg = Atom.to_string(field) <> ": " <> msg
|
|
%{"error" => error_msg}
|
|
end
|
|
|
|
def handle_errors(conn, %{kind: kind, reason: reason}) do
|
|
json(conn, %{error: Exception.format_banner(kind, reason)})
|
|
end
|
|
end
|