Some checks failed
deploy / deploy (push) Failing after 8m33s
- Add Hammer library for rate limiting with ETS backend - Rate limit login (5/min), magic link (3/min), newsletter (10/min), API (60/min) - Add themed 429 error page using bare shop styling - Enable HSTS in production with rewrite_on for Fly proxy - Add security hardening plan to docs Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
30 lines
808 B
Elixir
30 lines
808 B
Elixir
defmodule BerrypodWeb.ContactController do
|
|
use BerrypodWeb, :controller
|
|
|
|
alias Berrypod.ContactNotifier
|
|
|
|
plug BerrypodWeb.Plugs.RateLimit, [type: :api] when action == :create
|
|
|
|
@doc """
|
|
Handles contact form submission (no-JS fallback).
|
|
"""
|
|
def create(conn, params) do
|
|
case ContactNotifier.deliver_contact_message(params) do
|
|
{:ok, _} ->
|
|
conn
|
|
|> put_flash(:info, "Message sent! We'll get back to you soon.")
|
|
|> redirect(to: ~p"/contact")
|
|
|
|
{:error, :invalid_params} ->
|
|
conn
|
|
|> put_flash(:error, "Please fill in all required fields.")
|
|
|> redirect(to: ~p"/contact")
|
|
|
|
{:error, _} ->
|
|
conn
|
|
|> put_flash(:error, "Sorry, something went wrong. Please try again.")
|
|
|> redirect(to: ~p"/contact")
|
|
end
|
|
end
|
|
end
|