defmodule CanneryWeb.UserRegistrationController do use CanneryWeb, :controller import CanneryWeb.Gettext alias Cannery.{Accounts, Accounts.Invites} alias CanneryWeb.{Endpoint, HomeLive} def new(conn, %{"invite" => invite_token}) do if Invites.valid_invite_token?(invite_token) do conn |> render_new(invite_token) else conn |> put_flash(:error, dgettext("errors", "Sorry, this invite was not found or expired")) |> redirect(to: Routes.live_path(Endpoint, HomeLive)) end end def new(conn, _params) do if Accounts.allow_registration?() do conn |> render_new() else conn |> put_flash(:error, dgettext("errors", "Sorry, public registration is disabled")) |> redirect(to: Routes.live_path(Endpoint, HomeLive)) end end # renders new user registration page defp render_new(conn, invite_token \\ nil) do render(conn, "new.html", changeset: Accounts.change_user_registration(), invite_token: invite_token, page_title: gettext("Register") ) end def create(conn, %{"user" => %{"invite_token" => invite_token}} = attrs) do if Invites.valid_invite_token?(invite_token) do conn |> create_user(attrs, invite_token) else conn |> put_flash(:error, dgettext("errors", "Sorry, this invite was not found or expired")) |> redirect(to: Routes.live_path(Endpoint, HomeLive)) end end def create(conn, attrs) do if Accounts.allow_registration?() do conn |> create_user(attrs) else conn |> put_flash(:error, dgettext("errors", "Sorry, public registration is disabled")) |> redirect(to: Routes.live_path(Endpoint, HomeLive)) end end defp create_user(conn, %{"user" => user_params}, invite_token \\ nil) do case Accounts.register_user(user_params, invite_token) do {:ok, user} -> Accounts.deliver_user_confirmation_instructions( user, &Routes.user_confirmation_url(conn, :confirm, &1) ) conn |> put_flash(:info, dgettext("prompts", "Please check your email to verify your account")) |> redirect(to: Routes.user_session_path(Endpoint, :new)) {:error, :invalid_token} -> conn |> put_flash(:error, dgettext("errors", "Sorry, this invite was not found or expired")) |> redirect(to: Routes.live_path(Endpoint, HomeLive)) {:error, %Ecto.Changeset{} = changeset} -> conn |> render("new.html", changeset: changeset, invite_token: invite_token) end end end