Implement client kick endpoint

This commit is contained in:
Pim Kunis 2021-08-26 14:32:24 +02:00
parent 07d3326c07
commit bb7c3b07e9
7 changed files with 127 additions and 17 deletions

View file

@ -6,7 +6,7 @@ defmodule MatrixServerWeb.Client.RoomController do
alias MatrixServer.{Repo, Room, RoomServer}
alias MatrixServer.Types.UserId
alias MatrixServerWeb.Client.Request.CreateRoom
alias MatrixServerWeb.Client.Request.{CreateRoom, Kick}
alias Ecto.Changeset
alias Plug.Conn
@ -111,8 +111,6 @@ defmodule MatrixServerWeb.Client.RoomController do
end
end
def join(conn, _), do: put_error(conn, :missing_param)
@doc """
This API stops a user participating in a particular room.
@ -136,5 +134,26 @@ defmodule MatrixServerWeb.Client.RoomController do
end
end
def leave(conn, _), do: put_error(conn, :missing_param)
@doc """
Kick a user from the room.
Action for POST /_matrix/client/r0/rooms/{roomId}/kick.
"""
def kick(%Conn{assigns: %{account: account}} = conn, %{"room_id" => room_id} = params) do
with {:ok, request} <- Kick.parse(params),
{:ok, pid} <- RoomServer.get_room_server(room_id) do
case RoomServer.kick(pid, account, request) do
:ok ->
conn
|> send_resp(200, [])
|> halt()
{:error, _} ->
put_error(conn, :unknown)
end
else
{:error, %Ecto.Changeset{}} -> put_error(conn, :bad_json)
{:error, :not_found} -> put_error(conn, :not_found, "Room not found.")
end
end
end

View file

@ -0,0 +1,20 @@
defmodule MatrixServerWeb.Client.Request.Kick do
use MatrixServerWeb.Request
@type t :: %__MODULE__{
user_id: String.t(),
reason: String.t() | nil
}
@primary_key false
embedded_schema do
field :user_id, :string
field :reason, :string
end
def changeset(data, params) do
data
|> cast(params, [:user_id, :reason])
|> validate_required([:user_id])
end
end