1
0
mirror of https://github.com/danbee/chess synced 2025-03-04 08:39:06 +00:00
chess/lib/chess_web/controllers/api/game_controller.ex

62 lines
1.2 KiB
Elixir

defmodule ChessWeb.Api.GameController do
use ChessWeb, :controller
alias Chess.Store.Game
alias Chess.Board
import Chess.Auth, only: [current_user: 1]
def show(conn, %{"id" => id}) do
game =
conn
|> current_user()
|> Game.for_user()
|> Repo.get!(id)
conn
|> json(game_attrs(conn, game))
end
def update(conn, %{"id" => id, "move" => move_params}) do
game =
conn
|> current_user()
|> Game.for_user()
|> Repo.get!(id)
changeset = Game.changeset(
game, %{board: new_board(game.board, move_params)}
)
case Repo.update(changeset) do
{:ok, game} ->
conn
|> json(Board.transform(game.board))
end
end
defp game_attrs(conn, game) do
%{
board: Board.transform(game.board),
player: player(conn, game)
}
end
defp player(conn, game) do
if game.user_id == current_user(conn).id do
"white"
else
"black"
end
end
defp new_board(board, move_params) do
[from_file, from_rank] = move_params["from"]
[to_file, to_rank] = move_params["to"]
{piece, board} = Map.pop(board, "#{from_file},#{from_rank}")
Map.put(board, "#{to_file},#{to_rank}", piece)
end
end