c7edb8a48c
* generate a phoenix API only project * adds /api/rolldice endpoint and opentelemetry configuration * change span attribute name to match implementations in other langs --------- Co-authored-by: Tristan Sloughter <t@crashfast.com>
67 lines
1.5 KiB
Elixir
67 lines
1.5 KiB
Elixir
defmodule RollDiceWeb do
|
|
@moduledoc """
|
|
The entrypoint for defining your web interface, such
|
|
as controllers, components, channels, and so on.
|
|
|
|
This can be used in your application as:
|
|
|
|
use RollDiceWeb, :controller
|
|
use RollDiceWeb, :html
|
|
|
|
The definitions below will be executed for every controller,
|
|
component, etc, so keep them short and clean, focused
|
|
on imports, uses and aliases.
|
|
|
|
Do NOT define functions inside the quoted expressions
|
|
below. Instead, define additional modules and import
|
|
those modules here.
|
|
"""
|
|
|
|
def static_paths, do: ~w(assets fonts images favicon.ico robots.txt)
|
|
|
|
def router do
|
|
quote do
|
|
use Phoenix.Router, helpers: false
|
|
|
|
# Import common connection and controller functions to use in pipelines
|
|
import Plug.Conn
|
|
import Phoenix.Controller
|
|
end
|
|
end
|
|
|
|
def channel do
|
|
quote do
|
|
use Phoenix.Channel
|
|
end
|
|
end
|
|
|
|
def controller do
|
|
quote do
|
|
use Phoenix.Controller,
|
|
formats: [:html, :json],
|
|
layouts: [html: RollDiceWeb.Layouts]
|
|
|
|
import Plug.Conn
|
|
import RollDiceWeb.Gettext
|
|
|
|
unquote(verified_routes())
|
|
end
|
|
end
|
|
|
|
def verified_routes do
|
|
quote do
|
|
use Phoenix.VerifiedRoutes,
|
|
endpoint: RollDiceWeb.Endpoint,
|
|
router: RollDiceWeb.Router,
|
|
statics: RollDiceWeb.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
|