2017-12-08 09:58:14 +01:00
|
|
|
defmodule EventosWeb.EventController do
|
2018-01-14 17:56:50 +01:00
|
|
|
@moduledoc """
|
|
|
|
Controller for Events
|
|
|
|
"""
|
2017-12-08 09:58:14 +01:00
|
|
|
use EventosWeb, :controller
|
|
|
|
|
|
|
|
alias Eventos.Events
|
|
|
|
alias Eventos.Events.Event
|
2018-01-15 11:40:01 +01:00
|
|
|
alias Eventos.Export.ICalendar
|
2018-01-21 19:43:16 +01:00
|
|
|
alias Eventos.Addresses
|
2017-12-08 09:58:14 +01:00
|
|
|
|
2018-06-14 17:25:55 +02:00
|
|
|
import Logger
|
|
|
|
|
2018-01-13 23:33:03 +01:00
|
|
|
action_fallback EventosWeb.FallbackController
|
|
|
|
|
2017-12-08 09:58:14 +01:00
|
|
|
def index(conn, _params) do
|
|
|
|
events = Events.list_events()
|
2018-01-13 23:33:03 +01:00
|
|
|
render(conn, "index.json", events: events)
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def create(conn, %{"event" => event_params}) do
|
2018-06-06 17:42:53 +02:00
|
|
|
address = process_address(event_params["address"])
|
|
|
|
event_params = if is_nil address do
|
|
|
|
event_params
|
|
|
|
else
|
|
|
|
%{event_params | "address" => address}
|
|
|
|
end
|
2018-01-13 23:33:03 +01:00
|
|
|
with {:ok, %Event{} = event} <- Events.create_event(event_params) do
|
|
|
|
conn
|
|
|
|
|> put_status(:created)
|
2018-06-06 17:42:53 +02:00
|
|
|
|> put_resp_header("location", event_path(conn, :show, event.uuid))
|
2018-01-16 19:45:09 +01:00
|
|
|
|> render("show_simple.json", event: event)
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-01-17 11:39:01 +01:00
|
|
|
defp process_address(address) do
|
2018-06-06 17:42:53 +02:00
|
|
|
geom = EventosWeb.AddressController.process_geom(address["geom"])
|
|
|
|
case geom do
|
|
|
|
nil ->
|
|
|
|
address
|
|
|
|
_ ->
|
2018-01-17 11:39:01 +01:00
|
|
|
%{address | "geom" => geom}
|
2018-01-21 19:43:16 +01:00
|
|
|
_ ->
|
|
|
|
address
|
2018-01-17 11:39:01 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-05-30 14:27:21 +02:00
|
|
|
def search(conn, %{"name" => name}) do
|
|
|
|
events = Events.find_events_by_name(name)
|
|
|
|
render(conn, "index.json", events: events)
|
|
|
|
end
|
|
|
|
|
2018-06-06 17:42:53 +02:00
|
|
|
def show(conn, %{"uuid" => uuid}) do
|
2018-06-14 17:25:55 +02:00
|
|
|
case Events.get_event_full_by_uuid(uuid) do
|
|
|
|
nil ->
|
|
|
|
send_resp(conn, 404, "")
|
|
|
|
event ->
|
|
|
|
render(conn, "show.json", event: event)
|
|
|
|
end
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
|
|
|
|
2018-06-06 17:42:53 +02:00
|
|
|
def export_to_ics(conn, %{"uuid" => uuid}) do
|
|
|
|
event = Events.get_event_full_by_uuid(uuid) |> ICalendar.export_event()
|
2018-01-15 11:40:01 +01:00
|
|
|
send_resp(conn, 200, event)
|
|
|
|
end
|
|
|
|
|
2018-06-06 17:42:53 +02:00
|
|
|
def update(conn, %{"uuid" => uuid, "event" => event_params}) do
|
|
|
|
event = Events.get_event_full_by_uuid(uuid)
|
2017-12-08 09:58:14 +01:00
|
|
|
|
2018-01-13 23:33:03 +01:00
|
|
|
with {:ok, %Event{} = event} <- Events.update_event(event, event_params) do
|
2018-01-16 19:45:09 +01:00
|
|
|
render(conn, "show_simple.json", event: event)
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-06 17:42:53 +02:00
|
|
|
def delete(conn, %{"uuid" => uuid}) do
|
2018-06-14 17:25:55 +02:00
|
|
|
with event <- Events.get_event_by_uuid(uuid),
|
|
|
|
{:ok, %Event{}} <- Events.delete_event(event) do
|
2018-01-13 23:33:03 +01:00
|
|
|
send_resp(conn, :no_content, "")
|
|
|
|
end
|
2017-12-08 09:58:14 +01:00
|
|
|
end
|
|
|
|
end
|