mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-11-23 20:18:00 +01:00
87 lines
2 KiB
Elixir
87 lines
2 KiB
Elixir
defmodule PhilomenaWeb do
|
|
@moduledoc """
|
|
The entrypoint for defining your web interface, such
|
|
as controllers, views, channels and so on.
|
|
|
|
This can be used in your application as:
|
|
|
|
use PhilomenaWeb, :controller
|
|
use PhilomenaWeb, :view
|
|
|
|
The definitions below will be executed for every view,
|
|
controller, etc, so keep them short and clean, focused
|
|
on imports, uses and aliases.
|
|
|
|
Do NOT define functions inside the quoted expressions
|
|
below. Instead, define any helper function in modules
|
|
and import those modules here.
|
|
"""
|
|
|
|
def static_paths, do: ~w(assets favicon.ico favicon.svg robots.txt opensearch.xml)
|
|
|
|
def controller do
|
|
quote do
|
|
use Phoenix.Controller, namespace: PhilomenaWeb
|
|
|
|
import Plug.Conn
|
|
import PhilomenaWeb.Gettext
|
|
import Canary.Plugs
|
|
import PhilomenaWeb.ModerationLogPlug, only: [moderation_log: 2]
|
|
|
|
unquote(verified_routes())
|
|
end
|
|
end
|
|
|
|
def view do
|
|
quote do
|
|
use Phoenix.View,
|
|
root: "lib/philomena_web/templates",
|
|
namespace: PhilomenaWeb
|
|
|
|
# Import convenience functions from controllers
|
|
import Phoenix.Controller, only: [view_module: 1]
|
|
|
|
# Use all HTML functionality (forms, tags, etc)
|
|
use Phoenix.HTML
|
|
|
|
import PhilomenaWeb.ErrorHelpers
|
|
import PhilomenaWeb.Gettext
|
|
|
|
# Wrong way around for convenience
|
|
import PhilomenaWeb.AppView
|
|
|
|
unquote(verified_routes())
|
|
end
|
|
end
|
|
|
|
def router do
|
|
quote do
|
|
use Phoenix.Router
|
|
import Plug.Conn
|
|
import Phoenix.Controller
|
|
end
|
|
end
|
|
|
|
def channel do
|
|
quote do
|
|
use Phoenix.Channel
|
|
import PhilomenaWeb.Gettext
|
|
end
|
|
end
|
|
|
|
def verified_routes do
|
|
quote do
|
|
use Phoenix.VerifiedRoutes,
|
|
endpoint: PhilomenaWeb.Endpoint,
|
|
router: PhilomenaWeb.Router,
|
|
statics: PhilomenaWeb.static_paths()
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
When used, dispatch to the appropriate controller/view/etc.
|
|
"""
|
|
defmacro __using__(which) when is_atom(which) do
|
|
apply(__MODULE__, which, [])
|
|
end
|
|
end
|