diff --git a/README.md b/README.md index 4a8bd2f..d1457fb 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,6 @@ # ExqUI - +#This is a complete fork from akira/exq_ui +#it's a temporary measure to support phoenix_html 4 +, when they are able to bump their side, this repo will be closed [![Hex.pm](https://img.shields.io/hexpm/v/exq_ui.svg)](https://hex.pm/packages/exq_ui) ExqUI provides a UI dashboard for [Exq](https://github.com/akira/exq), a job processing library diff --git a/config/config.exs b/config/config.exs index c5b5a9c..79f6096 100644 --- a/config/config.exs +++ b/config/config.exs @@ -7,7 +7,7 @@ config :exq, port: 6379, namespace: "exq" -config :exq_ui, +config :exq_ui_fork, api_name: Exq.Api, exq_scheduler_name: ExqScheduler diff --git a/config/test.exs b/config/test.exs index 8cf5560..911cc93 100644 --- a/config/test.exs +++ b/config/test.exs @@ -1,9 +1,9 @@ import Config # Print only warnings and errors during test -config :logger, level: :warn +config :logger, level: :warning -config :exq_ui, DemoWeb.Endpoint, +config :exq_ui_fork, DemoWeb.Endpoint, secret_key_base: "JUrii8hEdYZjAo/LHUziUO1xx0ViDK+I1yYDVvNrLpcYWH93l4kSBvWsbfGwJRu5", live_view: [signing_salt: "jhwmDSe0"], pubsub_server: ExqUI.PubSub diff --git a/dev.exs b/dev.exs index c647dd4..3f5d722 100644 --- a/dev.exs +++ b/dev.exs @@ -2,7 +2,7 @@ Logger.configure(level: :debug) Application.ensure_all_started(:exq_scheduler) # Configures the endpoint -Application.put_env(:exq_ui, DemoWeb.Endpoint, +Application.put_env(:exq_ui_fork, DemoWeb.Endpoint, url: [host: "localhost"], secret_key_base: "JUrii8hEdYZjAo/LHUziUO1xx0ViDK+I1yYDVvNrLpcYWH93l4kSBvWsbfGwJRu5", live_view: [signing_salt: "jhwmDSe0"], @@ -47,7 +47,7 @@ defmodule DemoWeb.Router do end defmodule DemoWeb.Endpoint do - use Phoenix.Endpoint, otp_app: :exq_ui + use Phoenix.Endpoint, otp_app: :exq_ui_fork @session_options [ store: :cookie, diff --git a/lib/exq_ui/queue.ex b/lib/exq_ui/queue.ex index 415e40d..9a08de4 100644 --- a/lib/exq_ui/queue.ex +++ b/lib/exq_ui/queue.ex @@ -233,6 +233,6 @@ defmodule ExqUI.Queue do end def api do - Application.get_env(:exq_ui, :api_name, Exq.Api) + Application.get_env(:exq_ui_fork, :api_name, Exq.Api) end end diff --git a/lib/exq_ui_web.ex b/lib/exq_ui_web.ex index f58bb84..cfb23be 100644 --- a/lib/exq_ui_web.ex +++ b/lib/exq_ui_web.ex @@ -55,7 +55,9 @@ defmodule ExqUIWeb do defp view_helpers do quote do # Use all HTML functionality (forms, tags, etc) - use Phoenix.HTML + import Phoenix.HTML + import Phoenix.HTML.Form + use PhoenixHTMLHelpers import Phoenix.Component # Import LiveView helpers (live_render, live_component, live_patch, etc) diff --git a/lib/exq_ui_web/live/busy_live/index.html.heex b/lib/exq_ui_web/live/busy_live/index.html.heex index bea5b9d..79797c6 100644 --- a/lib/exq_ui_web/live/busy_live/index.html.heex +++ b/lib/exq_ui_web/live/busy_live/index.html.heex @@ -13,8 +13,11 @@
- <%= node.identity %> - <%= form_for :signal, "#", [id: "node-#{node.identity}", phx_auto_recover: :ignore, phx_change: :signal, class: "mb-0 form-check form-switch form-check-inline"], fn f -> %> + + <%= node.identity %> + + <%= form_for :signal, "#" , [id: "node-#{node.identity}" , phx_auto_recover: :ignore, phx_change: :signal, + class: "mb-0 form-check form-switch form-check-inline" ], fn f -> %> <%= hidden_input(f, :name, value: "TSTP") %> <%= hidden_input(f, :node_id, value: node.identity) %> <%= checkbox(f, :quiet, @@ -26,10 +29,15 @@ ) %> <% end %>
- Queues: <%= Enum.join(node.queues, ", ") %> + Queues: + <%= Enum.join(node.queues, ", ") %> + + + <%= human_time(node.started_at) %> + + + <%= node.busy %> - <%= human_time(node.started_at) %> - <%= node.busy %> <% end %> @@ -50,18 +58,29 @@ <%= for job <- @jobs do %> - <%= job.host %> - <%= job.pid %> - <%= job.payload.jid %> - <%= live_redirect(job.queue, - class: "nounderline", - to: Routes.queue_show_path(@socket, job.queue) - ) %> + <%= job.host %> + + + <%= job.pid %> + + + <%= job.payload.jid %> + + + <.link navigate={Routes.queue_show_path(@socket, job.queue)} class="nounderline"> + <%= job.queue %> + + + + <%= job.payload.class %> + + + <%= inspect(job.payload.args) %> + + + <%= human_time(job.run_at) %> - <%= job.payload.class %> - <%= inspect(job.payload.args) %> - <%= human_time(job.run_at) %> <% end %> diff --git a/lib/exq_ui_web/live/components/nav_bar_component.html.heex b/lib/exq_ui_web/live/components/nav_bar_component.html.heex index cc45ac7..d846e7a 100644 --- a/lib/exq_ui_web/live/components/nav_bar_component.html.heex +++ b/lib/exq_ui_web/live/components/nav_bar_component.html.heex @@ -4,26 +4,61 @@
- <%= form_for :table, "#", [phx_submit: :action], fn f -> %> + <%= form_for :table, "#" , [phx_submit: :action], fn f -> %> @@ -31,7 +31,9 @@ <%= for %{header: header} <- @columns do %> - <%= header %> + + <%= header %> + <% end %> @@ -45,8 +47,19 @@ class: "form-check-input js-select-row" ) %> - <%= for %{accessor: accessor} = column <- @columns do %> - <%= accessor.(item) %> + <%= for column <- @columns do %> + + <%= if column[:link] do %> + <.link + navigate={column.accessor.(item)[:link]} + class={column.accessor.(item)[:class]} + > + <%= column.accessor.(item)[:text] %> + + <% else %> + <%= column.accessor.(item) %> + <% end %> + <% end %> <% end %> diff --git a/lib/exq_ui_web/live/dead_live/index.ex b/lib/exq_ui_web/live/dead_live/index.ex index 3efff03..4cab1ca 100644 --- a/lib/exq_ui_web/live/dead_live/index.ex +++ b/lib/exq_ui_web/live/dead_live/index.ex @@ -11,11 +11,13 @@ defmodule ExqUIWeb.DeadLive.Index do assign(socket, :columns, [ %{ header: "Last Failed", + link: true, accessor: fn item -> - live_redirect(human_time(item.scheduled_at), - to: Routes.dead_show_path(socket, item.score, item.id), + %{ + text: human_time(item.scheduled_at), + link: Routes.dead_show_path(socket, item.score, item.id), class: "nounderline" - ) + } end }, %{header: "Retry Count", accessor: fn item -> item.job.retry_count end}, diff --git a/lib/exq_ui_web/live/queue_live/index.html.heex b/lib/exq_ui_web/live/queue_live/index.html.heex index 773f334..471a677 100644 --- a/lib/exq_ui_web/live/queue_live/index.html.heex +++ b/lib/exq_ui_web/live/queue_live/index.html.heex @@ -12,22 +12,25 @@ - <%= live_redirect(queue.name, - class: "nounderline", - to: Routes.queue_show_path(@socket, queue.name) - ) %> + <.link navigate={Routes.queue_show_path(@socket, queue.name)} class="nounderline"> + <%= queue.name %> + - <%= queue.count %> + + <%= queue.count %> + - <%= link("Delete", - class: "btn btn-danger btn-sm", - to: "#", - phx_click: "delete", - phx_value_name: queue.name, - data: [confirm: "Are you sure?"] - ) %> + <.link + navigate="#" + phx-click="delete" + phx-value-name={queue.name} + data-confirm="Are you sure?" + class="btn btn-danger btn-sm" + > + Delete + diff --git a/lib/exq_ui_web/live/recurring_live/index.ex b/lib/exq_ui_web/live/recurring_live/index.ex index cae9929..989bf33 100644 --- a/lib/exq_ui_web/live/recurring_live/index.ex +++ b/lib/exq_ui_web/live/recurring_live/index.ex @@ -39,6 +39,6 @@ defmodule ExqUIWeb.RecurringLive.Index do end defp scheduler do - Application.get_env(:exq_ui, :exq_scheduler_name, ExqScheduler) + Application.get_env(:exq_ui_fork, :exq_scheduler_name, ExqScheduler) end end diff --git a/lib/exq_ui_web/live/retry_live/index.ex b/lib/exq_ui_web/live/retry_live/index.ex index 7ed46fb..7d908a1 100644 --- a/lib/exq_ui_web/live/retry_live/index.ex +++ b/lib/exq_ui_web/live/retry_live/index.ex @@ -11,11 +11,13 @@ defmodule ExqUIWeb.RetryLive.Index do assign(socket, :columns, [ %{ header: "Next Retry", + link: true, accessor: fn item -> - live_redirect(human_time(item.scheduled_at), - to: Routes.retry_show_path(socket, item.score, item.id), + %{ + text: human_time(item.scheduled_at), + link: Routes.retry_show_path(socket, item.score, item.id), class: "nounderline" - ) + } end }, %{header: "Retry Count", accessor: fn item -> item.job.retry_count end}, diff --git a/lib/exq_ui_web/live/scheduled_live/index.ex b/lib/exq_ui_web/live/scheduled_live/index.ex index 80d8743..a856d3c 100644 --- a/lib/exq_ui_web/live/scheduled_live/index.ex +++ b/lib/exq_ui_web/live/scheduled_live/index.ex @@ -11,11 +11,13 @@ defmodule ExqUIWeb.ScheduledLive.Index do assign(socket, :columns, [ %{ header: "When", + link: true, accessor: fn item -> - live_redirect(human_time(item.scheduled_at), - to: Routes.scheduled_show_path(socket, item.score, item.id), + %{ + text: human_time(item.scheduled_at), + link: Routes.scheduled_show_path(socket, item.score, item.id), class: "nounderline" - ) + } end }, %{header: "Queue", accessor: fn item -> item.job.queue end}, diff --git a/lib/exq_ui_web/router.ex b/lib/exq_ui_web/router.ex index b273aeb..1d52ed5 100644 --- a/lib/exq_ui_web/router.ex +++ b/lib/exq_ui_web/router.ex @@ -7,7 +7,7 @@ defmodule ExqUIWeb.Router do ## Options - * live_session_name - Name of the live_session. Defaults to `:exq_ui` + * live_session_name - Name of the live_session. Defaults to `:exq_ui_fork` * live_socket_path - Should match the value used for `socket "/live", Phoenix.LiveView.Socket`. Defaults to `/live` * live_session_on_mount - Declares an optional module callback to be invoked on the LiveView's mount """ @@ -30,7 +30,7 @@ defmodule ExqUIWeb.Router do live "/scheduled", ExqUIWeb.ScheduledLive.Index, :index, route_opts live "/scheduled/:score/:jid", ExqUIWeb.ScheduledLive.Show, :index, route_opts - if Application.compile_env(:exq_ui, :exq_scheduler_name) do + if Application.compile_env(:exq_ui_fork, :exq_scheduler_name) do live "/recurring", ExqUIWeb.RecurringLive.Index, :index, route_opts end end @@ -54,7 +54,7 @@ defmodule ExqUIWeb.Router do @doc false def __options__(options) do - session_name = options[:live_session_name] || :exq_ui + session_name = options[:live_session_name] || :exq_ui_fork session_opts = [ session: {__MODULE__, :__session__, []}, @@ -72,7 +72,7 @@ defmodule ExqUIWeb.Router do route_opts = [ private: %{live_socket_path: Keyword.get(options, :live_socket_path, "/live")}, - as: :exq_ui + as: :exq_ui_fork ] {session_name, session_opts, route_opts} diff --git a/lib/exq_ui_web/templates/layout/root.html.heex b/lib/exq_ui_web/templates/layout/root.html.heex index 21c6bb9..5e84ab3 100644 --- a/lib/exq_ui_web/templates/layout/root.html.heex +++ b/lib/exq_ui_web/templates/layout/root.html.heex @@ -5,7 +5,9 @@ <%= csrf_meta_tag() %> - <%= live_title_tag(assigns[:page_title] || "ExqUI") %> + <.live_title> + <%= assigns[:page_title] || "ExqUI" %> + @@ -13,6 +15,7 @@ <%= raw(render("app.js")) %> + <%= @inner_content %> diff --git a/lib/exq_ui_web/views/helpers.ex b/lib/exq_ui_web/views/helpers.ex index bb9afa4..5de7344 100644 --- a/lib/exq_ui_web/views/helpers.ex +++ b/lib/exq_ui_web/views/helpers.ex @@ -1,17 +1,14 @@ defmodule ExqUIWeb.Helpers do @moduledoc false - use Phoenix.HTML - import Phoenix.LiveView.Helpers - def nav_link(socket, name, link) do - active = - if String.contains?(Atom.to_string(socket.view), String.slice(name, 0..3)) do - " active" - else - "" - end + use PhoenixHTMLHelpers - live_redirect(name, to: link, class: "nav-link" <> active) + def nav_link_class(socket, name) do + if String.contains?(Atom.to_string(socket.view), String.slice(name, 0..3)) do + "nav-link active" + else + "nav-link" + end end def human_time(nil) do diff --git a/mix.exs b/mix.exs index 0594279..40f075c 100644 --- a/mix.exs +++ b/mix.exs @@ -5,7 +5,7 @@ defmodule ExqUI.MixProject do def project do [ - app: :exq_ui, + app: :exq_ui_fork, version: @version, elixir: "~> 1.12", elixirc_paths: elixirc_paths(Mix.env()), @@ -36,9 +36,10 @@ defmodule ExqUI.MixProject do [ {:exq, ">= 0.16.2"}, {:exq_scheduler, "~> 1.0", optional: true}, - {:phoenix_live_view, "~> 0.18"}, + {:phoenix_live_view, "~> 0.20.12"}, {:phoenix_live_reload, "~> 1.2", only: :dev}, {:phoenix_view, "~> 2.0"}, + {:phoenix_html_helpers, "~> 1.0"}, {:jason, "~> 1.0"}, {:plug_cowboy, "~> 2.0"}, {:redix, ">= 0.9.0"}, @@ -50,6 +51,7 @@ defmodule ExqUI.MixProject do defp package do [ + name: "exq_ui_fork", description: """ Exq UI is the UI component for Exq, a job processing library. Exq UI provides the UI dashboard to display stats on job processing. diff --git a/mix.lock b/mix.lock index a6f2c94..5f3d730 100644 --- a/mix.lock +++ b/mix.lock @@ -1,53 +1,56 @@ %{ "benchee": {:hex, :benchee, "1.0.1", "66b211f9bfd84bd97e6d1beaddf8fc2312aaabe192f776e8931cb0c16f53a521", [:mix], [{:deep_merge, "~> 1.0", [hex: :deep_merge, repo: "hexpm", optional: false]}], "hexpm", "3ad58ae787e9c7c94dd7ceda3b587ec2c64604563e049b2a0e8baafae832addb"}, - "castore": {:hex, :castore, "0.1.22", "4127549e411bedd012ca3a308dede574f43819fe9394254ca55ab4895abfa1a2", [:mix], [], "hexpm", "c17576df47eb5aa1ee40cc4134316a99f5cad3e215d5c77b8dd3cfef12a22cac"}, - "certifi": {:hex, :certifi, "2.9.0", "6f2a475689dd47f19fb74334859d460a2dc4e3252a3324bd2111b8f0429e7e21", [:rebar3], [], "hexpm", "266da46bdb06d6c6d35fde799bcb28d36d985d424ad7c08b5bb48f5b5cdd4641"}, + "castore": {:hex, :castore, "1.0.7", "b651241514e5f6956028147fe6637f7ac13802537e895a724f90bf3e36ddd1dd", [:mix], [], "hexpm", "da7785a4b0d2a021cd1292a60875a784b6caef71e76bf4917bdee1f390455cf5"}, + "certifi": {:hex, :certifi, "2.12.0", "2d1cca2ec95f59643862af91f001478c9863c2ac9cb6e2f89780bfd8de987329", [:rebar3], [], "hexpm", "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"}, "combine": {:hex, :combine, "0.10.0", "eff8224eeb56498a2af13011d142c5e7997a80c8f5b97c499f84c841032e429f", [:mix], [], "hexpm", "1b1dbc1790073076580d0d1d64e42eae2366583e7aecd455d1215b0d16f2451b"}, - "cowboy": {:hex, :cowboy, "2.10.0", "ff9ffeff91dae4ae270dd975642997afe2a1179d94b1887863e43f681a203e26", [:make, :rebar3], [{:cowlib, "2.12.1", [hex: :cowlib, repo: "hexpm", optional: false]}, {:ranch, "1.8.0", [hex: :ranch, repo: "hexpm", optional: false]}], "hexpm", "3afdccb7183cc6f143cb14d3cf51fa00e53db9ec80cdcd525482f5e99bc41d6b"}, + "cowboy": {:hex, :cowboy, "2.12.0", "f276d521a1ff88b2b9b4c54d0e753da6c66dd7be6c9fca3d9418b561828a3731", [:make, :rebar3], [{:cowlib, "2.13.0", [hex: :cowlib, repo: "hexpm", optional: false]}, {:ranch, "1.8.0", [hex: :ranch, repo: "hexpm", optional: false]}], "hexpm", "8a7abe6d183372ceb21caa2709bec928ab2b72e18a3911aa1771639bef82651e"}, "cowboy_telemetry": {:hex, :cowboy_telemetry, "0.4.0", "f239f68b588efa7707abce16a84d0d2acf3a0f50571f8bb7f56a15865aae820c", [:rebar3], [{:cowboy, "~> 2.7", [hex: :cowboy, repo: "hexpm", optional: false]}, {:telemetry, "~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "7d98bac1ee4565d31b62d59f8823dfd8356a169e7fcbb83831b8a5397404c9de"}, - "cowlib": {:hex, :cowlib, "2.12.1", "a9fa9a625f1d2025fe6b462cb865881329b5caff8f1854d1cbc9f9533f00e1e1", [:make, :rebar3], [], "hexpm", "163b73f6367a7341b33c794c4e88e7dbfe6498ac42dcd69ef44c5bc5507c8db0"}, - "crontab": {:hex, :crontab, "1.1.11", "4028ced51b813a5061f85b689d4391ef0c27550c8ab09aaf139e4295c3d93ea4", [:mix], [{:ecto, "~> 1.0 or ~> 2.0 or ~> 3.0", [hex: :ecto, repo: "hexpm", optional: true]}], "hexpm", "ecb045f9ac14a3e2990e54368f70cdb6e2f2abafc5bc329d6c31f0c74b653787"}, + "cowlib": {:hex, :cowlib, "2.13.0", "db8f7505d8332d98ef50a3ef34b34c1afddec7506e4ee4dd4a3a266285d282ca", [:make, :rebar3], [], "hexpm", "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"}, + "crontab": {:hex, :crontab, "1.1.13", "3bad04f050b9f7f1c237809e42223999c150656a6b2afbbfef597d56df2144c5", [:mix], [{:ecto, "~> 1.0 or ~> 2.0 or ~> 3.0", [hex: :ecto, repo: "hexpm", optional: true]}], "hexpm", "d67441bec989640e3afb94e123f45a2bc42d76e02988c9613885dc3d01cf7085"}, "deep_merge": {:hex, :deep_merge, "1.0.0", "b4aa1a0d1acac393bdf38b2291af38cb1d4a52806cf7a4906f718e1feb5ee961", [:mix], [], "hexpm", "ce708e5f094b9cd4e8f2be4f00d2f4250c4095be93f8cd6d018c753894885430"}, - "earmark_parser": {:hex, :earmark_parser, "1.4.18", "e1b2be73eb08a49fb032a0208bf647380682374a725dfb5b9e510def8397f6f2", [:mix], [], "hexpm", "114a0e85ec3cf9e04b811009e73c206394ffecfcc313e0b346de0d557774ee97"}, + "earmark_parser": {:hex, :earmark_parser, "1.4.39", "424642f8335b05bb9eb611aa1564c148a8ee35c9c8a8bba6e129d51a3e3c6769", [:mix], [], "hexpm", "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"}, "elixir_uuid": {:hex, :elixir_uuid, "1.2.1", "dce506597acb7e6b0daeaff52ff6a9043f5919a4c3315abb4143f0b00378c097", [:mix], [], "hexpm", "f7eba2ea6c3555cea09706492716b0d87397b88946e6380898c2889d68585752"}, - "ex_doc": {:hex, :ex_doc, "0.26.0", "1922164bac0b18b02f84d6f69cab1b93bc3e870e2ad18d5dacb50a9e06b542a3", [:mix], [{:earmark_parser, "~> 1.4.0", [hex: :earmark_parser, repo: "hexpm", optional: false]}, {:makeup_elixir, "~> 0.14", [hex: :makeup_elixir, repo: "hexpm", optional: false]}, {:makeup_erlang, "~> 0.1", [hex: :makeup_erlang, repo: "hexpm", optional: false]}], "hexpm", "2775d66e494a9a48355db7867478ffd997864c61c65a47d31c4949459281c78d"}, - "exq": {:hex, :exq, "0.16.2", "601c0486ce5eec5bcbda882b989a1d65a3611b729d8a92e402a77c87a0c367d8", [:mix], [{:elixir_uuid, ">= 1.2.0", [hex: :elixir_uuid, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:poison, ">= 1.2.0 and < 5.0.0", [hex: :poison, repo: "hexpm", optional: true]}, {:redix, ">= 0.9.0", [hex: :redix, repo: "hexpm", optional: false]}], "hexpm", "7a0c5ff3d305c4dfb5a02d4c49f13a528e82039059716c70085ad10dfce7d018"}, + "ex_doc": {:hex, :ex_doc, "0.32.1", "21e40f939515373bcdc9cffe65f3b3543f05015ac6c3d01d991874129d173420", [:mix], [{:earmark_parser, "~> 1.4.39", [hex: :earmark_parser, repo: "hexpm", optional: false]}, {:makeup_c, ">= 0.1.1", [hex: :makeup_c, repo: "hexpm", optional: true]}, {:makeup_elixir, "~> 0.14", [hex: :makeup_elixir, repo: "hexpm", optional: false]}, {:makeup_erlang, "~> 0.1", [hex: :makeup_erlang, repo: "hexpm", optional: false]}], "hexpm", "5142c9db521f106d61ff33250f779807ed2a88620e472ac95dc7d59c380113da"}, + "expo": {:hex, :expo, "0.5.2", "beba786aab8e3c5431813d7a44b828e7b922bfa431d6bfbada0904535342efe2", [:mix], [], "hexpm", "8c9bfa06ca017c9cb4020fabe980bc7fdb1aaec059fd004c2ab3bff03b1c599c"}, + "exq": {:hex, :exq, "0.19.0", "06eb92944dad39f0954dc8f63190d3e24d11734eef88cf5800883e57ebf74f3c", [:mix], [{:elixir_uuid, ">= 1.2.0", [hex: :elixir_uuid, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:poison, ">= 1.2.0 and < 6.0.0", [hex: :poison, repo: "hexpm", optional: true]}, {:redix, ">= 0.9.0", [hex: :redix, repo: "hexpm", optional: false]}], "hexpm", "24fc0ebdd87cc7406e1034fb46c2419f9c8a362f0ec634d23b6b819514d36390"}, "exq_scheduler": {:hex, :exq_scheduler, "1.0.0", "fdac27c41be4930c88260b03c6f27167f1b92221587a69b26173b6af48d068b0", [:mix], [{:crontab, "~> 1.1", [hex: :crontab, repo: "hexpm", optional: false]}, {:elixir_uuid, "~> 1.2", [hex: :elixir_uuid, repo: "hexpm", optional: false]}, {:poison, "~> 3.1 or ~> 4.0 or ~> 5.0", [hex: :poison, repo: "hexpm", optional: true]}, {:redix, "~> 0.7 or ~> 1.0", [hex: :redix, repo: "hexpm", optional: false]}, {:timex, "~> 3.7", [hex: :timex, repo: "hexpm", optional: false]}, {:tzdata, "~> 1.0", [hex: :tzdata, repo: "hexpm", optional: false]}], "hexpm", "2b89d79fa9db91bbf78e3757f9b8b1b846e351aef82063c0baeb8081c3230264"}, - "file_system": {:hex, :file_system, "0.2.10", "fb082005a9cd1711c05b5248710f8826b02d7d1784e7c3451f9c1231d4fc162d", [:mix], [], "hexpm", "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"}, - "floki": {:hex, :floki, "0.31.0", "f05ee8a8e6a3ced4e62beeb2c79a63bc8e12ab98fbaaf6e6a3d9b76b1278e23f", [:mix], [{:html_entities, "~> 0.5.0", [hex: :html_entities, repo: "hexpm", optional: false]}], "hexpm", "b05afa372f5c345a5bf240ac25ea1f0f3d5fcfd7490ac0beeb4a203f9444891e"}, - "gettext": {:hex, :gettext, "0.18.2", "7df3ea191bb56c0309c00a783334b288d08a879f53a7014341284635850a6e55", [:mix], [], "hexpm", "f9f537b13d4fdd30f3039d33cb80144c3aa1f8d9698e47d7bcbcc8df93b1f5c5"}, - "hackney": {:hex, :hackney, "1.18.1", "f48bf88f521f2a229fc7bae88cf4f85adc9cd9bcf23b5dc8eb6a1788c662c4f6", [:rebar3], [{:certifi, "~>2.9.0", [hex: :certifi, repo: "hexpm", optional: false]}, {:idna, "~>6.1.0", [hex: :idna, repo: "hexpm", optional: false]}, {:metrics, "~>1.0.0", [hex: :metrics, repo: "hexpm", optional: false]}, {:mimerl, "~>1.1", [hex: :mimerl, repo: "hexpm", optional: false]}, {:parse_trans, "3.3.1", [hex: :parse_trans, repo: "hexpm", optional: false]}, {:ssl_verify_fun, "~>1.1.0", [hex: :ssl_verify_fun, repo: "hexpm", optional: false]}, {:unicode_util_compat, "~>0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "a4ecdaff44297e9b5894ae499e9a070ea1888c84afdd1fd9b7b2bc384950128e"}, + "file_system": {:hex, :file_system, "1.0.0", "b689cc7dcee665f774de94b5a832e578bd7963c8e637ef940cd44327db7de2cd", [:mix], [], "hexpm", "6752092d66aec5a10e662aefeed8ddb9531d79db0bc145bb8c40325ca1d8536d"}, + "floki": {:hex, :floki, "0.36.2", "a7da0193538c93f937714a6704369711998a51a6164a222d710ebd54020aa7a3", [:mix], [], "hexpm", "a8766c0bc92f074e5cb36c4f9961982eda84c5d2b8e979ca67f5c268ec8ed580"}, + "gettext": {:hex, :gettext, "0.24.0", "6f4d90ac5f3111673cbefc4ebee96fe5f37a114861ab8c7b7d5b30a1108ce6d8", [:mix], [{:expo, "~> 0.5.1", [hex: :expo, repo: "hexpm", optional: false]}], "hexpm", "bdf75cdfcbe9e4622dd18e034b227d77dd17f0f133853a1c73b97b3d6c770e8b"}, + "hackney": {:hex, :hackney, "1.20.1", "8d97aec62ddddd757d128bfd1df6c5861093419f8f7a4223823537bad5d064e2", [:rebar3], [{:certifi, "~> 2.12.0", [hex: :certifi, repo: "hexpm", optional: false]}, {:idna, "~> 6.1.0", [hex: :idna, repo: "hexpm", optional: false]}, {:metrics, "~> 1.0.0", [hex: :metrics, repo: "hexpm", optional: false]}, {:mimerl, "~> 1.1", [hex: :mimerl, repo: "hexpm", optional: false]}, {:parse_trans, "3.4.1", [hex: :parse_trans, repo: "hexpm", optional: false]}, {:ssl_verify_fun, "~> 1.1.0", [hex: :ssl_verify_fun, repo: "hexpm", optional: false]}, {:unicode_util_compat, "~> 0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "fe9094e5f1a2a2c0a7d10918fee36bfec0ec2a979994cff8cfe8058cd9af38e3"}, "html_entities": {:hex, :html_entities, "0.5.2", "9e47e70598da7de2a9ff6af8758399251db6dbb7eebe2b013f2bbd2515895c3c", [:mix], [], "hexpm", "c53ba390403485615623b9531e97696f076ed415e8d8058b1dbaa28181f4fdcc"}, - "idna": {:hex, :idna, "6.1.1", "8a63070e9f7d0c62eb9d9fcb360a7de382448200fbbd1b106cc96d3d8099df8d", [:rebar3], [{:unicode_util_compat, "~>0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"}, + "idna": {:hex, :idna, "6.1.1", "8a63070e9f7d0c62eb9d9fcb360a7de382448200fbbd1b106cc96d3d8099df8d", [:rebar3], [{:unicode_util_compat, "~> 0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"}, "jason": {:hex, :jason, "1.4.1", "af1504e35f629ddcdd6addb3513c3853991f694921b1b9368b0bd32beb9f1b63", [:mix], [{:decimal, "~> 1.0 or ~> 2.0", [hex: :decimal, repo: "hexpm", optional: true]}], "hexpm", "fbb01ecdfd565b56261302f7e1fcc27c4fb8f32d56eab74db621fc154604a7a1"}, - "makeup": {:hex, :makeup, "1.0.5", "d5a830bc42c9800ce07dd97fa94669dfb93d3bf5fcf6ea7a0c67b2e0e4a7f26c", [:mix], [{:nimble_parsec, "~> 0.5 or ~> 1.0", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "cfa158c02d3f5c0c665d0af11512fed3fba0144cf1aadee0f2ce17747fba2ca9"}, - "makeup_elixir": {:hex, :makeup_elixir, "0.15.2", "dc72dfe17eb240552857465cc00cce390960d9a0c055c4ccd38b70629227e97c", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.1", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "fd23ae48d09b32eff49d4ced2b43c9f086d402ee4fd4fcb2d7fad97fa8823e75"}, - "makeup_erlang": {:hex, :makeup_erlang, "0.1.1", "3fcb7f09eb9d98dc4d208f49cc955a34218fc41ff6b84df7c75b3e6e533cc65f", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "174d0809e98a4ef0b3309256cbf97101c6ec01c4ab0b23e926a9e17df2077cbb"}, + "makeup": {:hex, :makeup, "1.1.1", "fa0bc768698053b2b3869fa8a62616501ff9d11a562f3ce39580d60860c3a55e", [:mix], [{:nimble_parsec, "~> 1.2.2 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "5dc62fbdd0de44de194898b6710692490be74baa02d9d108bc29f007783b0b48"}, + "makeup_elixir": {:hex, :makeup_elixir, "0.16.2", "627e84b8e8bf22e60a2579dad15067c755531fea049ae26ef1020cad58fe9578", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.2.3 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "41193978704763f6bbe6cc2758b84909e62984c7752b3784bd3c218bb341706b"}, + "makeup_erlang": {:hex, :makeup_erlang, "0.1.5", "e0ff5a7c708dda34311f7522a8758e23bfcd7d8d8068dc312b5eb41c6fd76eba", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "94d2e986428585a21516d7d7149781480013c56e30c6a233534bedf38867a59a"}, "metrics": {:hex, :metrics, "1.0.1", "25f094dea2cda98213cecc3aeff09e940299d950904393b2a29d191c346a8486", [:rebar3], [], "hexpm", "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"}, "mime": {:hex, :mime, "2.0.5", "dc34c8efd439abe6ae0343edbb8556f4d63f178594894720607772a041b04b02", [:mix], [], "hexpm", "da0d64a365c45bc9935cc5c8a7fc5e49a0e0f9932a761c55d6c52b142780a05c"}, - "mimerl": {:hex, :mimerl, "1.2.0", "67e2d3f571088d5cfd3e550c383094b47159f3eee8ffa08e64106cdf5e981be3", [:rebar3], [], "hexpm", "f278585650aa581986264638ebf698f8bb19df297f66ad91b18910dfc6e19323"}, - "nimble_parsec": {:hex, :nimble_parsec, "1.2.0", "b44d75e2a6542dcb6acf5d71c32c74ca88960421b6874777f79153bbbbd7dccc", [:mix], [], "hexpm", "52b2871a7515a5ac49b00f214e4165a40724cf99798d8e4a65e4fd64ebd002c1"}, + "mimerl": {:hex, :mimerl, "1.3.0", "d0cd9fc04b9061f82490f6581e0128379830e78535e017f7780f37fea7545726", [:rebar3], [], "hexpm", "a1e15a50d1887217de95f0b9b0793e32853f7c258a5cd227650889b38839fe9d"}, + "nimble_options": {:hex, :nimble_options, "1.1.0", "3b31a57ede9cb1502071fade751ab0c7b8dbe75a9a4c2b5bbb0943a690b63172", [:mix], [], "hexpm", "8bbbb3941af3ca9acc7835f5655ea062111c9c27bcac53e004460dfd19008a99"}, + "nimble_parsec": {:hex, :nimble_parsec, "1.4.0", "51f9b613ea62cfa97b25ccc2c1b4216e81df970acd8e16e8d1bdc58fef21370d", [:mix], [], "hexpm", "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"}, "nimble_strftime": {:hex, :nimble_strftime, "0.1.1", "b988184d1bd945bc139b2c27dd00a6c0774ec94f6b0b580083abd62d5d07818b", [:mix], [], "hexpm", "89e599c9b8b4d1203b7bb5c79eb51ef7c6a28fbc6228230b312f8b796310d755"}, - "parse_trans": {:hex, :parse_trans, "3.3.1", "16328ab840cc09919bd10dab29e431da3af9e9e7e7e6f0089dd5a2d2820011d8", [:rebar3], [], "hexpm", "07cd9577885f56362d414e8c4c4e6bdf10d43a8767abb92d24cbe8b24c54888b"}, - "phoenix": {:hex, :phoenix, "1.7.7", "4cc501d4d823015007ba3cdd9c41ecaaf2ffb619d6fb283199fa8ddba89191e0", [:mix], [{:castore, ">= 0.0.0", [hex: :castore, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:phoenix_pubsub, "~> 2.1", [hex: :phoenix_pubsub, repo: "hexpm", optional: false]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}, {:phoenix_view, "~> 2.0", [hex: :phoenix_view, repo: "hexpm", optional: true]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}, {:plug_cowboy, "~> 2.6", [hex: :plug_cowboy, repo: "hexpm", optional: true]}, {:plug_crypto, "~> 1.2", [hex: :plug_crypto, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}, {:websock_adapter, "~> 0.5.3", [hex: :websock_adapter, repo: "hexpm", optional: false]}], "hexpm", "8966e15c395e5e37591b6ed0bd2ae7f48e961f0f60ac4c733f9566b519453085"}, - "phoenix_html": {:hex, :phoenix_html, "3.3.2", "d6ce982c6d8247d2fc0defe625255c721fb8d5f1942c5ac051f6177bffa5973f", [:mix], [{:plug, "~> 1.5", [hex: :plug, repo: "hexpm", optional: true]}], "hexpm", "44adaf8e667c1c20fb9d284b6b0fa8dc7946ce29e81ce621860aa7e96de9a11d"}, - "phoenix_live_reload": {:hex, :phoenix_live_reload, "1.3.3", "3a53772a6118d5679bf50fc1670505a290e32a1d195df9e069d8c53ab040c054", [:mix], [{:file_system, "~> 0.2.1 or ~> 0.3", [hex: :file_system, repo: "hexpm", optional: false]}, {:phoenix, "~> 1.4", [hex: :phoenix, repo: "hexpm", optional: false]}], "hexpm", "766796676e5f558dbae5d1bdb066849673e956005e3730dfd5affd7a6da4abac"}, - "phoenix_live_view": {:hex, :phoenix_live_view, "0.18.18", "1f38fbd7c363723f19aad1a04b5490ff3a178e37daaf6999594d5f34796c47fc", [:mix], [{:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:phoenix, "~> 1.6.15 or ~> 1.7.0", [hex: :phoenix, repo: "hexpm", optional: false]}, {:phoenix_html, "~> 3.3", [hex: :phoenix_html, repo: "hexpm", optional: false]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}, {:phoenix_view, "~> 2.0", [hex: :phoenix_view, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4.2 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "a5810d0472f3189ede6d2a95bda7f31c6113156b91784a3426cb0ab6a6d85214"}, + "parse_trans": {:hex, :parse_trans, "3.4.1", "6e6aa8167cb44cc8f39441d05193be6e6f4e7c2946cb2759f015f8c56b76e5ff", [:rebar3], [], "hexpm", "620a406ce75dada827b82e453c19cf06776be266f5a67cff34e1ef2cbb60e49a"}, + "phoenix": {:hex, :phoenix, "1.7.12", "1cc589e0eab99f593a8aa38ec45f15d25297dd6187ee801c8de8947090b5a9d3", [:mix], [{:castore, ">= 0.0.0", [hex: :castore, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:phoenix_pubsub, "~> 2.1", [hex: :phoenix_pubsub, repo: "hexpm", optional: false]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}, {:phoenix_view, "~> 2.0", [hex: :phoenix_view, repo: "hexpm", optional: true]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}, {:plug_cowboy, "~> 2.7", [hex: :plug_cowboy, repo: "hexpm", optional: true]}, {:plug_crypto, "~> 1.2 or ~> 2.0", [hex: :plug_crypto, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}, {:websock_adapter, "~> 0.5.3", [hex: :websock_adapter, repo: "hexpm", optional: false]}], "hexpm", "d646192fbade9f485b01bc9920c139bfdd19d0f8df3d73fd8eaf2dfbe0d2837c"}, + "phoenix_html": {:hex, :phoenix_html, "4.1.1", "4c064fd3873d12ebb1388425a8f2a19348cef56e7289e1998e2d2fa758aa982e", [:mix], [], "hexpm", "f2f2df5a72bc9a2f510b21497fd7d2b86d932ec0598f0210fed4114adc546c6f"}, + "phoenix_html_helpers": {:hex, :phoenix_html_helpers, "1.0.1", "7eed85c52eff80a179391036931791ee5d2f713d76a81d0d2c6ebafe1e11e5ec", [:mix], [{:phoenix_html, "~> 4.0", [hex: :phoenix_html, repo: "hexpm", optional: false]}, {:plug, "~> 1.5", [hex: :plug, repo: "hexpm", optional: true]}], "hexpm", "cffd2385d1fa4f78b04432df69ab8da63dc5cf63e07b713a4dcf36a3740e3090"}, + "phoenix_live_reload": {:hex, :phoenix_live_reload, "1.5.3", "f2161c207fda0e4fb55165f650f7f8db23f02b29e3bff00ff7ef161d6ac1f09d", [:mix], [{:file_system, "~> 0.3 or ~> 1.0", [hex: :file_system, repo: "hexpm", optional: false]}, {:phoenix, "~> 1.4", [hex: :phoenix, repo: "hexpm", optional: false]}], "hexpm", "b4ec9cd73cb01ff1bd1cac92e045d13e7030330b74164297d1aee3907b54803c"}, + "phoenix_live_view": {:hex, :phoenix_live_view, "0.20.14", "70fa101aa0539e81bed4238777498f6215e9dda3461bdaa067cad6908110c364", [:mix], [{:floki, "~> 0.36", [hex: :floki, repo: "hexpm", optional: true]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:phoenix, "~> 1.6.15 or ~> 1.7.0", [hex: :phoenix, repo: "hexpm", optional: false]}, {:phoenix_html, "~> 3.3 or ~> 4.0", [hex: :phoenix_html, repo: "hexpm", optional: false]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}, {:phoenix_view, "~> 2.0", [hex: :phoenix_view, repo: "hexpm", optional: true]}, {:plug, "~> 1.15", [hex: :plug, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.2 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "82f6d006c5264f979ed5eb75593d808bbe39020f20df2e78426f4f2d570e2402"}, "phoenix_pubsub": {:hex, :phoenix_pubsub, "2.1.3", "3168d78ba41835aecad272d5e8cd51aa87a7ac9eb836eabc42f6e57538e3731d", [:mix], [], "hexpm", "bba06bc1dcfd8cb086759f0edc94a8ba2bc8896d5331a1e2c2902bf8e36ee502"}, - "phoenix_template": {:hex, :phoenix_template, "1.0.3", "32de561eefcefa951aead30a1f94f1b5f0379bc9e340bb5c667f65f1edfa4326", [:mix], [{:phoenix_html, "~> 2.14.2 or ~> 3.0", [hex: :phoenix_html, repo: "hexpm", optional: true]}], "hexpm", "16f4b6588a4152f3cc057b9d0c0ba7e82ee23afa65543da535313ad8d25d8e2c"}, - "phoenix_view": {:hex, :phoenix_view, "2.0.2", "6bd4d2fd595ef80d33b439ede6a19326b78f0f1d8d62b9a318e3d9c1af351098", [:mix], [{:phoenix_html, "~> 2.14.2 or ~> 3.0", [hex: :phoenix_html, repo: "hexpm", optional: true]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}], "hexpm", "a929e7230ea5c7ee0e149ffcf44ce7cf7f4b6d2bfe1752dd7c084cdff152d36f"}, - "plug": {:hex, :plug, "1.14.2", "cff7d4ec45b4ae176a227acd94a7ab536d9b37b942c8e8fa6dfc0fff98ff4d80", [:mix], [{:mime, "~> 1.0 or ~> 2.0", [hex: :mime, repo: "hexpm", optional: false]}, {:plug_crypto, "~> 1.1.1 or ~> 1.2", [hex: :plug_crypto, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.3 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "842fc50187e13cf4ac3b253d47d9474ed6c296a8732752835ce4a86acdf68d13"}, - "plug_cowboy": {:hex, :plug_cowboy, "2.6.1", "9a3bbfceeb65eff5f39dab529e5cd79137ac36e913c02067dba3963a26efe9b2", [:mix], [{:cowboy, "~> 2.7", [hex: :cowboy, repo: "hexpm", optional: false]}, {:cowboy_telemetry, "~> 0.3", [hex: :cowboy_telemetry, repo: "hexpm", optional: false]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm", "de36e1a21f451a18b790f37765db198075c25875c64834bcc82d90b309eb6613"}, - "plug_crypto": {:hex, :plug_crypto, "1.2.5", "918772575e48e81e455818229bf719d4ab4181fcbf7f85b68a35620f78d89ced", [:mix], [], "hexpm", "26549a1d6345e2172eb1c233866756ae44a9609bd33ee6f99147ab3fd87fd842"}, + "phoenix_template": {:hex, :phoenix_template, "1.0.4", "e2092c132f3b5e5b2d49c96695342eb36d0ed514c5b252a77048d5969330d639", [:mix], [{:phoenix_html, "~> 2.14.2 or ~> 3.0 or ~> 4.0", [hex: :phoenix_html, repo: "hexpm", optional: true]}], "hexpm", "2c0c81f0e5c6753faf5cca2f229c9709919aba34fab866d3bc05060c9c444206"}, + "phoenix_view": {:hex, :phoenix_view, "2.0.3", "4d32c4817fce933693741deeb99ef1392619f942633dde834a5163124813aad3", [:mix], [{:phoenix_html, "~> 2.14.2 or ~> 3.0 or ~> 4.0", [hex: :phoenix_html, repo: "hexpm", optional: true]}, {:phoenix_template, "~> 1.0", [hex: :phoenix_template, repo: "hexpm", optional: false]}], "hexpm", "cd34049af41be2c627df99cd4eaa71fc52a328c0c3d8e7d4aa28f880c30e7f64"}, + "plug": {:hex, :plug, "1.15.3", "712976f504418f6dff0a3e554c40d705a9bcf89a7ccef92fc6a5ef8f16a30a97", [:mix], [{:mime, "~> 1.0 or ~> 2.0", [hex: :mime, repo: "hexpm", optional: false]}, {:plug_crypto, "~> 1.1.1 or ~> 1.2 or ~> 2.0", [hex: :plug_crypto, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.3 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "cc4365a3c010a56af402e0809208873d113e9c38c401cabd88027ef4f5c01fd2"}, + "plug_cowboy": {:hex, :plug_cowboy, "2.7.1", "87677ffe3b765bc96a89be7960f81703223fe2e21efa42c125fcd0127dd9d6b2", [:mix], [{:cowboy, "~> 2.7", [hex: :cowboy, repo: "hexpm", optional: false]}, {:cowboy_telemetry, "~> 0.3", [hex: :cowboy_telemetry, repo: "hexpm", optional: false]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm", "02dbd5f9ab571b864ae39418db7811618506256f6d13b4a45037e5fe78dc5de3"}, + "plug_crypto": {:hex, :plug_crypto, "2.0.0", "77515cc10af06645abbfb5e6ad7a3e9714f805ae118fa1a70205f80d2d70fe73", [:mix], [], "hexpm", "53695bae57cc4e54566d993eb01074e4d894b65a3766f1c43e2c61a1b0f45ea9"}, "ranch": {:hex, :ranch, "1.8.0", "8c7a100a139fd57f17327b6413e4167ac559fbc04ca7448e9be9057311597a1d", [:make, :rebar3], [], "hexpm", "49fbcfd3682fab1f5d109351b61257676da1a2fdbe295904176d5e521a2ddfe5"}, - "redix": {:hex, :redix, "1.1.5", "6fc460d66a5c2287e83e6d73dddc8d527ff59cb4d4f298b41e03a4db8c3b2bd5", [:mix], [{:castore, "~> 0.1.0", [hex: :castore, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4.0 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "679afdd4c14502fe9c11387ff1cdcb33065a1cf511097da1eee407f17c7a418b"}, - "ssl_verify_fun": {:hex, :ssl_verify_fun, "1.1.6", "cf344f5692c82d2cd7554f5ec8fd961548d4fd09e7d22f5b62482e5aeaebd4b0", [:make, :mix, :rebar3], [], "hexpm", "bdb0d2471f453c88ff3908e7686f86f9be327d065cc1ec16fa4540197ea04680"}, + "redix": {:hex, :redix, "1.5.0", "fffadf4526722ba9f062c0bda64e881613fbf99c2c1708692751def8fe6d546d", [:mix], [{:castore, "~> 0.1.0 or ~> 1.0", [hex: :castore, repo: "hexpm", optional: true]}, {:nimble_options, "~> 0.5.0 or ~> 1.0", [hex: :nimble_options, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.0 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "01084c005339c1eb8f2ba9e3737277ec3648d1e9b5c8e96525dcdb38e474ca96"}, + "ssl_verify_fun": {:hex, :ssl_verify_fun, "1.1.7", "354c321cf377240c7b8716899e182ce4890c5938111a1296add3ec74cf1715df", [:make, :mix, :rebar3], [], "hexpm", "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"}, "telemetry": {:hex, :telemetry, "1.2.1", "68fdfe8d8f05a8428483a97d7aab2f268aaff24b49e0f599faa091f1d4e7f61c", [:rebar3], [], "hexpm", "dad9ce9d8effc621708f99eac538ef1cbe05d6a874dd741de2e689c47feafed5"}, "telemetry_metrics": {:hex, :telemetry_metrics, "0.6.1", "315d9163a1d4660aedc3fee73f33f1d355dcc76c5c3ab3d59e76e3edf80eef1f", [:mix], [{:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "7be9e0871c41732c233be71e4be11b96e56177bf15dde64a8ac9ce72ac9834c6"}, "telemetry_poller": {:hex, :telemetry_poller, "0.5.1", "21071cc2e536810bac5628b935521ff3e28f0303e770951158c73eaaa01e962a", [:rebar3], [{:telemetry, "~> 0.4", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "4cab72069210bc6e7a080cec9afffad1b33370149ed5d379b81c7c5f0c663fd4"}, - "timex": {:hex, :timex, "3.7.9", "790cdfc4acfce434e442f98c02ea6d84d0239073bfd668968f82ac63e9a6788d", [:mix], [{:combine, "~> 0.10", [hex: :combine, repo: "hexpm", optional: false]}, {:gettext, "~> 0.10", [hex: :gettext, repo: "hexpm", optional: false]}, {:tzdata, "~> 1.1", [hex: :tzdata, repo: "hexpm", optional: false]}], "hexpm", "64691582e5bb87130f721fc709acfb70f24405833998fabf35be968984860ce1"}, + "timex": {:hex, :timex, "3.7.11", "bb95cb4eb1d06e27346325de506bcc6c30f9c6dea40d1ebe390b262fad1862d1", [:mix], [{:combine, "~> 0.10", [hex: :combine, repo: "hexpm", optional: false]}, {:gettext, "~> 0.20", [hex: :gettext, repo: "hexpm", optional: false]}, {:tzdata, "~> 1.1", [hex: :tzdata, repo: "hexpm", optional: false]}], "hexpm", "8b9024f7efbabaf9bd7aa04f65cf8dcd7c9818ca5737677c7b76acbc6a94d1aa"}, "tzdata": {:hex, :tzdata, "1.1.1", "20c8043476dfda8504952d00adac41c6eda23912278add38edc140ae0c5bcc46", [:mix], [{:hackney, "~> 1.17", [hex: :hackney, repo: "hexpm", optional: false]}], "hexpm", "a69cec8352eafcd2e198dea28a34113b60fdc6cb57eb5ad65c10292a6ba89787"}, "unicode_util_compat": {:hex, :unicode_util_compat, "0.7.0", "bc84380c9ab48177092f43ac89e4dfa2c6d62b40b8bd132b1059ecc7232f9a78", [:rebar3], [], "hexpm", "25eee6d67df61960cf6a794239566599b09e17e668d3700247bc498638152521"}, "websock": {:hex, :websock, "0.5.3", "2f69a6ebe810328555b6fe5c831a851f485e303a7c8ce6c5f675abeb20ebdadc", [:mix], [], "hexpm", "6105453d7fac22c712ad66fab1d45abdf049868f253cf719b625151460b8b453"}, - "websock_adapter": {:hex, :websock_adapter, "0.5.4", "7af8408e7ed9d56578539594d1ee7d8461e2dd5c3f57b0f2a5352d610ddde757", [:mix], [{:bandit, ">= 0.6.0", [hex: :bandit, repo: "hexpm", optional: true]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}, {:plug_cowboy, "~> 2.6", [hex: :plug_cowboy, repo: "hexpm", optional: true]}, {:websock, "~> 0.5", [hex: :websock, repo: "hexpm", optional: false]}], "hexpm", "d2c238c79c52cbe223fcdae22ca0bb5007a735b9e933870e241fce66afb4f4ab"}, + "websock_adapter": {:hex, :websock_adapter, "0.5.6", "0437fe56e093fd4ac422de33bf8fc89f7bc1416a3f2d732d8b2c8fd54792fe60", [:mix], [{:bandit, ">= 0.6.0", [hex: :bandit, repo: "hexpm", optional: true]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}, {:plug_cowboy, "~> 2.6", [hex: :plug_cowboy, repo: "hexpm", optional: true]}, {:websock, "~> 0.5", [hex: :websock, repo: "hexpm", optional: false]}], "hexpm", "e04378d26b0af627817ae84c92083b7e97aca3121196679b73c73b99d0d133ea"}, } diff --git a/test/exq_ui_web/live/busy_live/index_test.exs b/test/exq_ui_web/live/busy_live/index_test.exs index a1539c3..59f1a15 100644 --- a/test/exq_ui_web/live/busy_live/index_test.exs +++ b/test/exq_ui_web/live/busy_live/index_test.exs @@ -5,9 +5,9 @@ defmodule ExqUIWeb.BusyLive.IndexTest do {:ok, view, _} = live(conn, "/busy") html = render(view) - assert html =~ ~r/Queues:.*hard, soft/ - assert html =~ ~r/790fa550-08a4-42de-93e4-8c09c867befe/ - assert html =~ ~r/0aec2714-9032-4574-ae45-a2037c874d9f/ + assert html =~ ~r/Queues:.*hard, soft/s + assert html =~ ~r/790fa550-08a4-42de-93e4-8c09c867befe/s + assert html =~ ~r/0aec2714-9032-4574-ae45-a2037c874d9f/s end test "quiet", %{conn: conn} do diff --git a/test/exq_ui_web/live/dead_live/index_test.exs b/test/exq_ui_web/live/dead_live/index_test.exs index a40568b..77b7fd0 100644 --- a/test/exq_ui_web/live/dead_live/index_test.exs +++ b/test/exq_ui_web/live/dead_live/index_test.exs @@ -5,8 +5,8 @@ defmodule ExqUIWeb.DeadLive.IndexTest do {:ok, view, _} = live(conn, "/dead") html = render(view) - assert html =~ ~r/hard.*409.*RuntimeError/ - assert html =~ ~r/hard.*548.*kill/ + assert html =~ ~r/hard.*409.*RuntimeError/s + assert html =~ ~r/hard.*548.*kill/s end test "view and delete single job", %{conn: conn} do @@ -26,8 +26,8 @@ defmodule ExqUIWeb.DeadLive.IndexTest do |> follow_redirect(conn) html = render(view) - refute html =~ ~r/hard.*409.*RuntimeError/ - assert html =~ ~r/hard.*548.*kill/ + refute html =~ ~r/hard.*409.*RuntimeError/s + assert html =~ ~r/hard.*548.*kill/s end test "retry now", %{conn: conn} do @@ -47,19 +47,19 @@ defmodule ExqUIWeb.DeadLive.IndexTest do |> follow_redirect(conn) html = render(view) - refute html =~ ~r/hard.*409.*RuntimeError/ - assert html =~ ~r/hard.*548.*kill/ + refute html =~ ~r/hard.*409.*RuntimeError/s + assert html =~ ~r/hard.*548.*kill/s {:ok, view, _} = live(conn, "/queues/hard") html = render(view) - assert html =~ ~r/Hardworker.*409/ + assert html =~ ~r/Hardworker.*409/s end test "delete_all", %{conn: conn} do {:ok, view, _} = live(conn, "/dead") html = render(view) - assert html =~ ~r/hard.*409.*RuntimeError/ - assert html =~ ~r/hard.*548.*kill/ + assert html =~ ~r/hard.*409.*RuntimeError/s + assert html =~ ~r/hard.*548.*kill/s element( view, diff --git a/test/exq_ui_web/live/queue_live/index_test.exs b/test/exq_ui_web/live/queue_live/index_test.exs index c5c6d56..d87e9be 100644 --- a/test/exq_ui_web/live/queue_live/index_test.exs +++ b/test/exq_ui_web/live/queue_live/index_test.exs @@ -5,7 +5,7 @@ defmodule ExqUIWeb.QueueLive.IndexTest do {:ok, view, _} = live(conn, "/queues") html = render(view) - assert html =~ ~r/hard.*1.*Delete/ + assert html =~ ~r/hard.*1.*Delete/s html = element( @@ -15,7 +15,7 @@ defmodule ExqUIWeb.QueueLive.IndexTest do ) |> render_click() - refute html =~ ~r/hard.*1.*Delete/ + refute html =~ ~r/hard.*1.*Delete/s end test "view single queue", %{conn: conn} do @@ -27,6 +27,6 @@ defmodule ExqUIWeb.QueueLive.IndexTest do |> follow_redirect(conn) html = render(view) - assert html =~ ~r/Hardworker.*428/ + assert html =~ ~r/Hardworker.*428/s end end diff --git a/test/exq_ui_web/live/queue_live/show_test.exs b/test/exq_ui_web/live/queue_live/show_test.exs index 1383fd1..dd515ba 100644 --- a/test/exq_ui_web/live/queue_live/show_test.exs +++ b/test/exq_ui_web/live/queue_live/show_test.exs @@ -5,7 +5,7 @@ defmodule ExqUIWeb.QueueLive.ShowTest do {:ok, view, _} = live(conn, "/queues/hard") html = render(view) - assert html =~ ~r/Hardworker.*428/ + assert html =~ ~r/Hardworker.*428/s end test "delete_all", %{conn: conn} do @@ -18,7 +18,7 @@ defmodule ExqUIWeb.QueueLive.ShowTest do ) |> render_hook("action", %{"table" => %{"action" => "delete_all"}}) - refute html =~ ~r/Hardworker.*428/ + refute html =~ ~r/Hardworker.*428/s end test "delete", %{conn: conn} do @@ -37,6 +37,6 @@ defmodule ExqUIWeb.QueueLive.ShowTest do } }) - refute html =~ ~r/Hardworker.*428/ + refute html =~ ~r/Hardworker.*428/s end end diff --git a/test/exq_ui_web/live/recurring_live/index_test.exs b/test/exq_ui_web/live/recurring_live/index_test.exs index e42265f..3c67501 100644 --- a/test/exq_ui_web/live/recurring_live/index_test.exs +++ b/test/exq_ui_web/live/recurring_live/index_test.exs @@ -46,6 +46,6 @@ defmodule ExqUIWeb.RecurringLive.IndexTest do |> follow_redirect(conn) html = render(view) - assert html =~ ~r/Hardworker.*435493/ + assert html =~ ~r/Hardworker.*435493/s end end diff --git a/test/exq_ui_web/live/retry_live/index_test.exs b/test/exq_ui_web/live/retry_live/index_test.exs index 38ac255..3e54b3a 100644 --- a/test/exq_ui_web/live/retry_live/index_test.exs +++ b/test/exq_ui_web/live/retry_live/index_test.exs @@ -5,8 +5,8 @@ defmodule ExqUIWeb.RetryLive.IndexTest do {:ok, view, _} = live(conn, "/retries") html = render(view) - assert html =~ ~r/hard.*499.*{:bad, :reason}/ - assert html =~ ~r/hard.*235.*RuntimeError/ + assert html =~ ~r/hard.*499.*{:bad, :reason}/s + assert html =~ ~r/hard.*235.*RuntimeError/s end test "view and delete single job", %{conn: conn} do @@ -26,15 +26,15 @@ defmodule ExqUIWeb.RetryLive.IndexTest do |> follow_redirect(conn) html = render(view) - refute html =~ ~r/hard.*499.*{:bad, :reason}/ - assert html =~ ~r/hard.*235.*RuntimeError/ + refute html =~ ~r/hard.*499.*{:bad, :reason}/s + assert html =~ ~r/hard.*235.*RuntimeError/s end test "delete_all", %{conn: conn} do {:ok, view, _} = live(conn, "/retries") html = render(view) - assert html =~ ~r/hard.*499.*{:bad, :reason}/ - assert html =~ ~r/hard.*235.*RuntimeError/ + assert html =~ ~r/hard.*499.*{:bad, :reason}/s + assert html =~ ~r/hard.*235.*RuntimeError/s element( view, @@ -65,11 +65,11 @@ defmodule ExqUIWeb.RetryLive.IndexTest do |> follow_redirect(conn) html = render(view) - refute html =~ ~r/hard.*499.*{:bad, :reason}/ - assert html =~ ~r/hard.*235.*RuntimeError/ + refute html =~ ~r/hard.*499.*{:bad, :reason}/s + assert html =~ ~r/hard.*235.*RuntimeError/s {:ok, view, _} = live(conn, "/queues/hard") html = render(view) - assert html =~ ~r/Hardworker.*499/ + assert html =~ ~r/Hardworker.*499/s end end diff --git a/test/exq_ui_web/live/scheduled_live/index_test.exs b/test/exq_ui_web/live/scheduled_live/index_test.exs index 5d7e7bd..62486ff 100644 --- a/test/exq_ui_web/live/scheduled_live/index_test.exs +++ b/test/exq_ui_web/live/scheduled_live/index_test.exs @@ -5,8 +5,8 @@ defmodule ExqUIWeb.ScheduledLive.IndexTest do {:ok, view, _} = live(conn, "/scheduled") html = render(view) - assert html =~ ~r/Hardworker.*864/ - assert html =~ ~r/Hardworker.*509/ + assert html =~ ~r/Hardworker.*864/s + assert html =~ ~r/Hardworker.*509/s end test "view and delete single job", %{conn: conn} do @@ -26,15 +26,15 @@ defmodule ExqUIWeb.ScheduledLive.IndexTest do |> follow_redirect(conn) html = render(view) - assert html =~ ~r/Hardworker.*864/ - refute html =~ ~r/Hardworker.*509/ + assert html =~ ~r/Hardworker.*864/s + refute html =~ ~r/Hardworker.*509/s end test "delete_all", %{conn: conn} do {:ok, view, _} = live(conn, "/scheduled") html = render(view) - assert html =~ ~r/Hardworker.*864/ - assert html =~ ~r/Hardworker.*509/ + assert html =~ ~r/Hardworker.*864/s + assert html =~ ~r/Hardworker.*509/s element( view, @@ -44,8 +44,8 @@ defmodule ExqUIWeb.ScheduledLive.IndexTest do {:ok, view, _} = live(conn, "/scheduled") html = render(view) - refute html =~ ~r/Hardworker.*864/ - refute html =~ ~r/Hardworker.*509/ + refute html =~ ~r/Hardworker.*864/s + refute html =~ ~r/Hardworker.*509/s end test "add to queue", %{conn: conn} do @@ -65,11 +65,11 @@ defmodule ExqUIWeb.ScheduledLive.IndexTest do |> follow_redirect(conn) html = render(view) - assert html =~ ~r/Hardworker.*864/ - refute html =~ ~r/Hardworker.*509/ + assert html =~ ~r/Hardworker.*864/s + refute html =~ ~r/Hardworker.*509/s {:ok, view, _} = live(conn, "/queues/hard") html = render(view) - assert html =~ ~r/Hardworker.*509/ + assert html =~ ~r/Hardworker.*509/s end end diff --git a/test/support/conn_case.ex b/test/support/conn_case.ex index b917ee2..6a3e872 100644 --- a/test/support/conn_case.ex +++ b/test/support/conn_case.ex @@ -14,7 +14,7 @@ defmodule DemoWeb.Router do end defmodule DemoWeb.Endpoint do - use Phoenix.Endpoint, otp_app: :exq_ui + use Phoenix.Endpoint, otp_app: :exq_ui_fork @session_options [ store: :cookie,