b3b41ad777
* Data doesn't need anymore to be converted to ActivityStream format to be saved (this was taken from Pleroma and not at all a good idea here) * Everything saved when creating an event is inserted into PostgreSQL in a single transaction
73 lines
1.7 KiB
Elixir
73 lines
1.7 KiB
Elixir
defmodule Mobilizon.Addresses.Address do
|
|
@moduledoc """
|
|
Represents an address for an event or a group.
|
|
"""
|
|
|
|
use Ecto.Schema
|
|
|
|
import Ecto.Changeset
|
|
|
|
alias Mobilizon.Events.Event
|
|
|
|
@type t :: %__MODULE__{
|
|
country: String.t(),
|
|
locality: String.t(),
|
|
region: String.t(),
|
|
description: String.t(),
|
|
floor: String.t(),
|
|
geom: Geo.PostGIS.Geometry.t(),
|
|
postal_code: String.t(),
|
|
street: String.t(),
|
|
url: String.t(),
|
|
origin_id: String.t(),
|
|
events: [Event.t()]
|
|
}
|
|
|
|
@required_attrs [:url]
|
|
@optional_attrs [
|
|
:description,
|
|
:floor,
|
|
:geom,
|
|
:country,
|
|
:locality,
|
|
:region,
|
|
:postal_code,
|
|
:street,
|
|
:origin_id
|
|
]
|
|
@attrs @required_attrs ++ @optional_attrs
|
|
|
|
schema "addresses" do
|
|
field(:country, :string)
|
|
field(:locality, :string)
|
|
field(:region, :string)
|
|
field(:description, :string)
|
|
field(:floor, :string)
|
|
field(:geom, Geo.PostGIS.Geometry)
|
|
field(:postal_code, :string)
|
|
field(:street, :string)
|
|
field(:url, :string)
|
|
field(:origin_id, :string)
|
|
|
|
has_many(:events, Event, foreign_key: :physical_address_id)
|
|
|
|
timestamps()
|
|
end
|
|
|
|
@doc false
|
|
@spec changeset(t, map) :: Ecto.Changeset.t()
|
|
def changeset(%__MODULE__{} = address, attrs) do
|
|
address
|
|
|> cast(attrs, @attrs)
|
|
|> set_url()
|
|
|> validate_required(@required_attrs)
|
|
end
|
|
|
|
@spec set_url(Ecto.Changeset.t()) :: Ecto.Changeset.t()
|
|
defp set_url(%Ecto.Changeset{changes: changes} = changeset) do
|
|
url = Map.get(changes, :url, "#{MobilizonWeb.Endpoint.url()}/address/#{Ecto.UUID.generate()}")
|
|
|
|
put_change(changeset, :url, url)
|
|
end
|
|
end
|