diff options
Diffstat (limited to 'lib/silmataivas_web.ex')
| -rw-r--r-- | lib/silmataivas_web.ex | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/lib/silmataivas_web.ex b/lib/silmataivas_web.ex new file mode 100644 index 0000000..ef60499 --- /dev/null +++ b/lib/silmataivas_web.ex @@ -0,0 +1,67 @@ +defmodule SilmataivasWeb 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 SilmataivasWeb, :controller + use SilmataivasWeb, :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: SilmataivasWeb.Layouts] + + use Gettext, backend: SilmataivasWeb.Gettext + + import Plug.Conn + + unquote(verified_routes()) + end + end + + def verified_routes do + quote do + use Phoenix.VerifiedRoutes, + endpoint: SilmataivasWeb.Endpoint, + router: SilmataivasWeb.Router, + statics: SilmataivasWeb.static_paths() + end + end + + @doc """ + When used, dispatch to the appropriate controller/live_view/etc. + """ + defmacro __using__(which) when is_atom(which) do + apply(__MODULE__, which, []) + end +end |
