GP5JCAWTT4PW7MG3YC4GBP6ZQPB7XASKWTQCFVBIMZV3GZPOAETQC ExUnit.start()Ecto.Adapters.SQL.Sandbox.mode(Cake.Repo, :manual)
defmodule CakeWeb do@moduledoc """The entrypoint for defining your web interface, suchas controllers, views, channels and so on.This can be used in your application as:use CakeWeb, :controlleruse CakeWeb, :viewThe definitions below will be executed for every view,controller, etc, so keep them short and clean, focusedon imports, uses and aliases.Do NOT define functions inside the quoted expressionsbelow. Instead, define any helper function in modulesand import those modules here."""def controller doquote douse Phoenix.Controller, namespace: CakeWebimport Plug.Connimport CakeWeb.Gettextalias CakeWeb.Router.Helpers, as: Routesendenddef view doquote douse Phoenix.View,root: "lib/cake_web/templates",namespace: CakeWeb# Import convenience functions from controllersimport Phoenix.Controller,only: [get_flash: 1, get_flash: 2, view_module: 1, view_template: 1]# Include shared imports and aliases for viewsunquote(view_helpers())import Surfaceendenddef live_view doquote douse Phoenix.LiveView,layout: {CakeWeb.LayoutView, "live.html"}unquote(view_helpers())endenddef live_component doquote douse Phoenix.LiveComponentunquote(view_helpers())endenddef component doquote douse Phoenix.Componentunquote(view_helpers())endenddef router doquote douse Phoenix.Routerimport Plug.Connimport Phoenix.Controllerimport Phoenix.LiveView.Routerendenddef channel doquote douse Phoenix.Channelimport CakeWeb.Gettextendenddefp view_helpers doquote do# Use all HTML functionality (forms, tags, etc)use Phoenix.HTML# Import LiveView and .heex helpers (live_render, live_patch, <.form>, etc)import Phoenix.LiveView.Helpersimport CakeWeb.LiveHelpers# Import basic rendering functionality (render, render_layout, etc)import Phoenix.Viewimport CakeWeb.ErrorHelpersimport CakeWeb.Gettextalias CakeWeb.Router.Helpers, as: Routesendend@doc """When used, dispatch to the appropriate controller/view/etc."""defmacro __using__(which) when is_atom(which) doapply(__MODULE__, which, [])endend
defmodule Cake do@moduledoc """Cake keeps the contexts that define your domainand business logic.Contexts are also responsible for managing your data, regardlessif it comes from the database, an external API or others."""end
import Config# Configure your database## The MIX_TEST_PARTITION environment variable can be used# to provide built-in test partitioning in CI environment.# Run `mix help test` for more information.config :cake, Cake.Repo,username: "postgres",password: "postgres",hostname: "localhost",database: "cake_test#{System.get_env("MIX_TEST_PARTITION")}",pool: Ecto.Adapters.SQL.Sandbox,pool_size: 10# We don't run a server during test. If one is required,# you can enable the server option below.config :cake, CakeWeb.Endpoint,http: [ip: {127, 0, 0, 1}, port: 4002],secret_key_base: "MH8ZVoNHpJtxlu2SOymOb2+fB4NB5p9Eno5FxVyEQO1QrnD6H7QhURyZUlt4wyAU",server: false# In test we don't send emails.config :cake, Cake.Mailer, adapter: Swoosh.Adapters.Test# Print only warnings and errors during testconfig :logger, level: :warn# Initialize plugs at runtime for faster test compilationconfig :phoenix, :plug_init_mode, :runtime
import Config# config/runtime.exs is executed for all environments, including# during releases. It is executed after compilation and before the# system starts, so it is typically used to load production configuration# and secrets from environment variables or elsewhere. Do not define# any compile-time configuration in here, as it won't be applied.# The block below contains prod specific runtime configuration.# Start the phoenix server if environment is set and running in a releaseif System.get_env("PHX_SERVER") && System.get_env("RELEASE_NAME") doconfig :cake, CakeWeb.Endpoint, server: trueendif config_env() == :prod dodatabase_url =System.get_env("DATABASE_URL") ||raise """environment variable DATABASE_URL is missing.For example: ecto://USER:PASS@HOST/DATABASE"""maybe_ipv6 = if System.get_env("ECTO_IPV6"), do: [:inet6], else: []config :cake, Cake.Repo,# ssl: true,url: database_url,pool_size: String.to_integer(System.get_env("POOL_SIZE") || "10"),socket_options: maybe_ipv6# The secret key base is used to sign/encrypt cookies and other secrets.# A default value is used in config/dev.exs and config/test.exs but you# want to use a different value for prod and you most likely don't want# to check this value into version control, so we use an environment# variable instead.secret_key_base =System.get_env("SECRET_KEY_BASE") ||raise """environment variable SECRET_KEY_BASE is missing.You can generate one by calling: mix phx.gen.secret"""host = System.get_env("PHX_HOST") || "example.com"port = String.to_integer(System.get_env("PORT") || "4000")config :cake, CakeWeb.Endpoint,url: [host: host, port: 443],http: [# Enable IPv6 and bind on all interfaces.# Set it to {0, 0, 0, 0, 0, 0, 0, 1} for local network only access.# See the documentation on https://hexdocs.pm/plug_cowboy/Plug.Cowboy.html# for details about using IPv6 vs IPv4 and loopback vs public addresses.ip: {0, 0, 0, 0, 0, 0, 0, 0},port: port],secret_key_base: secret_key_base# ## Using releases## If you are doing OTP releases, you need to instruct Phoenix# to start each relevant endpoint:## config :cake, CakeWeb.Endpoint, server: true## Then you can assemble a release by calling `mix release`.# See `mix help release` for more information.# ## Configuring the mailer## In production you need to configure the mailer to use a different adapter.# Also, you may need to configure the Swoosh API client of your choice if you# are not using SMTP. Here is an example of the configuration:## config :cake, Cake.Mailer,# adapter: Swoosh.Adapters.Mailgun,# api_key: System.get_env("MAILGUN_API_KEY"),# domain: System.get_env("MAILGUN_DOMAIN")## For this example you need include a HTTP client required by Swoosh API client.# Swoosh supports Hackney and Finch out of the box:## config :swoosh, :api_client, Swoosh.ApiClient.Hackney## See https://hexdocs.pm/swoosh/Swoosh.html#module-installation for details.end
import Config# For production, don't forget to configure the url host# to something meaningful, Phoenix uses this information# when generating URLs.## Note we also include the path to a cache manifest# containing the digested version of static files. This# manifest is generated by the `mix phx.digest` task,# which you should run after static files are built and# before starting your production server.config :cake, CakeWeb.Endpoint, cache_static_manifest: "priv/static/cache_manifest.json"# Do not print debug messages in productionconfig :logger, level: :info# ## SSL Support## To get SSL working, you will need to add the `https` key# to the previous section and set your `:url` port to 443:## config :cake, CakeWeb.Endpoint,# ...,# url: [host: "example.com", port: 443],# https: [# ...,# port: 443,# cipher_suite: :strong,# keyfile: System.get_env("SOME_APP_SSL_KEY_PATH"),# certfile: System.get_env("SOME_APP_SSL_CERT_PATH")# ]## The `cipher_suite` is set to `:strong` to support only the# latest and more secure SSL ciphers. This means old browsers# and clients may not be supported. You can set it to# `:compatible` for wider support.## `:keyfile` and `:certfile` expect an absolute path to the key# and cert in disk or a relative path inside priv, for example# "priv/ssl/server.key". For all supported SSL configuration# options, see https://hexdocs.pm/plug/Plug.SSL.html#configure/1## We also recommend setting `force_ssl` in your endpoint, ensuring# no data is ever sent via http, always redirecting to https:## config :cake, CakeWeb.Endpoint,# force_ssl: [hsts: true]## Check `Plug.SSL` for all available options in `force_ssl`.
import Config# Configure your databaseconfig :cake, Cake.Repo,username: "postgres",password: "postgres",hostname: "localhost",database: "cake_dev",show_sensitive_data_on_connection_error: true,pool_size: 10# For development, we disable any cache and enable# debugging and code reloading.## The watchers configuration can be used to run external# watchers to your application. For example, we use it# with esbuild to bundle .js and .css sources.config :cake, CakeWeb.Endpoint,# Binding to loopback ipv4 address prevents access from other machines.# Change to `ip: {0, 0, 0, 0}` to allow access from other machines.http: [ip: {127, 0, 0, 1}, port: 4000],check_origin: false,code_reloader: true,debug_errors: true,secret_key_base: "3suRfViZZhN2hICJY79DfDNEo986ia1yZERJfVSgeLMoPb/hiXwkPMrK89wm0+yH",watchers: [# Start the esbuild watcher by calling Esbuild.install_and_run(:default, args)esbuild: {Esbuild, :install_and_run, [:default, ~w(--sourcemap=inline --watch)]},esbuild: {Esbuild, :install_and_run, [:catalogue, ~w(--sourcemap=inline --watch)]}]# ## SSL Support## In order to use HTTPS in development, a self-signed# certificate can be generated by running the following# Mix task:## mix phx.gen.cert## Note that this task requires Erlang/OTP 20 or later.# Run `mix help phx.gen.cert` for more information.## The `http:` config above can be replaced with:## https: [# port: 4001,# cipher_suite: :strong,# keyfile: "priv/cert/selfsigned_key.pem",# certfile: "priv/cert/selfsigned.pem"# ],## If desired, both `http:` and `https:` keys can be# configured to run both http and https servers on# different ports.# Watch static and templates for browser reloading.config :cake, CakeWeb.Endpoint,reloadable_compilers: [:gettext, :elixir, :surface],live_reload: [patterns: [~r"priv/static/.*(js|css|png|jpeg|jpg|gif|svg)$",~r"priv/gettext/.*(po)$",~r"lib/cake_web/(live|views|components)/.*(ex|sface|js)$",~r"lib/cake_web/templates/.*(eex)$",~r"priv/catalogue/.*(ex)$"]]# Do not include metadata nor timestamps in development logsconfig :logger, :console, format: "[$level] $message\n"# Set a higher stacktrace during development. Avoid configuring such# in production as building large stacktraces may be expensive.config :phoenix, :stacktrace_depth, 20# Initialize plugs at runtime for faster development compilationconfig :phoenix, :plug_init_mode, :runtime
# This file is responsible for configuring your application# and its dependencies with the aid of the Config module.## This configuration file is loaded before any dependency and# is restricted to this project.# General application configurationimport Configconfig :cake,ecto_repos: [Cake.Repo]# Configures the endpointconfig :cake, CakeWeb.Endpoint,url: [host: "localhost"],render_errors: [view: CakeWeb.ErrorView, accepts: ~w(html json), layout: false],pubsub_server: Cake.PubSub,live_view: [signing_salt: "mdS/Vlb/"]# Configures the mailer## By default it uses the "Local" adapter which stores the emails# locally. You can see the emails in your browser, at "/dev/mailbox".## For production it's recommended to configure a different adapter# at the `config/runtime.exs`.config :cake, Cake.Mailer, adapter: Swoosh.Adapters.Local# Swoosh API client is needed for adapters other than SMTP.config :swoosh, :api_client, false# Configure esbuild (the version is required)config :esbuild,version: "0.14.0",default: [args:~w(js/app.js --bundle --target=es2017 --outdir=../priv/static/assets --external:/fonts/* --external:/images/*),cd: Path.expand("../assets", __DIR__),env: %{"NODE_PATH" => Path.expand("../deps", __DIR__)}],catalogue: [args: ~w(../deps/surface_catalogue/assets/js/app.js --bundle --target=es2016 --minify --outdir=../priv/static/assets/catalogue),cd: Path.expand("../assets", __DIR__),env: %{"NODE_PATH" => Path.expand("../deps", __DIR__)}]# Configures Elixir's Loggerconfig :logger, :console,format: "$time $metadata[$level] $message\n",metadata: [:request_id]# Use Jason for JSON parsing in Phoenixconfig :phoenix, :json_library, Jasonconfig :surface, :components, [{Surface.Components.Form.ErrorTag, default_translator: {CakeWeb.ErrorHelpers, :translate_error}}]# Import environment specific config. This must remain at the bottom# of this file so it overrides the configuration defined above.import_config "#{config_env()}.exs"