From 287d64ffc4d4bc3393193a1a4bf14cab81781783 Mon Sep 17 00:00:00 2001 From: feng19 Date: Thu, 6 Aug 2020 09:50:41 +0800 Subject: [PATCH 1/2] feat(Cache): Supported Setting for Cache Adapter --- lib/open_api_spex/plug/cache.ex | 83 +++++++++++++++++++++++++++++---- 1 file changed, 73 insertions(+), 10 deletions(-) diff --git a/lib/open_api_spex/plug/cache.ex b/lib/open_api_spex/plug/cache.ex index 2deaeabb..5a9780dd 100644 --- a/lib/open_api_spex/plug/cache.ex +++ b/lib/open_api_spex/plug/cache.ex @@ -1,16 +1,54 @@ defmodule OpenApiSpex.Plug.Cache do - @moduledoc false + @moduledoc """ + Cache for OpenApiSpex - @callback get(module) :: {OpenApiSpex.OpenApi.t(), map} | nil - @callback put(module, {OpenApiSpex.OpenApi.t(), map}) :: :ok + Settings: - @spec adapter() :: OpenApiSpex.Plug.AppEnvCache | OpenApiSpex.Plug.PersistentTermCache - def adapter do - if function_exported?(:persistent_term, :info, 0) do + ```elixir + config :open_api_spex, :cache_adapter Module + ``` + + There are already had three cache adapter: + * `OpenApiSpex.Plug.PersistentTermCache` - default + * `OpenApiSpex.Plug.AppEnvCache` - if VM not supported `persistent_term` + * `OpenApiSpex.Plug.NoneCache` - none cache + + If you are constantly modifying specs during development, you can setting + like this in `dev.exs`: + + ```elixir + config :open_api_spex, :cache_adapter OpenApiSpex.Plug.NoneCache + ``` + """ + + default_adapter = + if(function_exported?(:persistent_term, :info, 0)) do OpenApiSpex.Plug.PersistentTermCache else OpenApiSpex.Plug.AppEnvCache end + + @default_adapter default_adapter + + @callback get(module) :: {OpenApiSpex.OpenApi.t(), map} | nil + @callback put(module, {OpenApiSpex.OpenApi.t(), map}) :: :ok + @callback erase(module) :: :ok + + @doc """ + Get cache adapter + """ + @spec adapter() :: module() + def adapter do + Application.get_env(:open_api_spex, :cache_adapter, @default_adapter) + end + + @doc """ + Only erase cache, put again when plug starting + """ + @spec refresh() :: :ok + def refresh do + adapter = adapter() + adapter.erase() end end @@ -18,15 +56,20 @@ defmodule OpenApiSpex.Plug.AppEnvCache do @moduledoc false @behaviour OpenApiSpex.Plug.Cache - @impl OpenApiSpex.Plug.Cache + @impl true def get(spec_module) do Application.get_env(:open_api_spex, spec_module) end - @impl OpenApiSpex.Plug.Cache + @impl true def put(spec_module, spec) do :ok = Application.put_env(:open_api_spex, spec_module, spec) end + + @impl true + def erase(spec_module) do + Application.delete_env(:open_api_spex, spec_module) + end end if function_exported?(:persistent_term, :info, 0) do @@ -34,7 +77,7 @@ if function_exported?(:persistent_term, :info, 0) do @moduledoc false @behaviour OpenApiSpex.Plug.Cache - @impl OpenApiSpex.Plug.Cache + @impl true def get(spec_module) do :persistent_term.get(spec_module) rescue @@ -42,9 +85,29 @@ if function_exported?(:persistent_term, :info, 0) do nil end - @impl OpenApiSpex.Plug.Cache + @impl true def put(spec_module, spec) do :ok = :persistent_term.put(spec_module, spec) end + + @impl true + def erase(spec_module) do + :persistent_term.erase(spec_module) + :ok + end end end + +defmodule OpenApiSpex.Plug.NoneCache do + @moduledoc false + @behaviour OpenApiSpex.Plug.Cache + + @impl true + def get(_spec_module), do: nil + + @impl true + def put(_spec_module, _spec), do: :ok + + @impl true + def erase(_spec_module), do: :ok +end From 74c2f8674cee2b38498fbb8765881692b2482d6c Mon Sep 17 00:00:00 2001 From: feng19 Date: Thu, 6 Aug 2020 10:15:26 +0800 Subject: [PATCH 2/2] feat(Cache): fix docs --- lib/open_api_spex/plug/cache.ex | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/open_api_spex/plug/cache.ex b/lib/open_api_spex/plug/cache.ex index 5a9780dd..eadb9fbf 100644 --- a/lib/open_api_spex/plug/cache.ex +++ b/lib/open_api_spex/plug/cache.ex @@ -5,7 +5,7 @@ defmodule OpenApiSpex.Plug.Cache do Settings: ```elixir - config :open_api_spex, :cache_adapter Module + config :open_api_spex, :cache_adapter, Module ``` There are already had three cache adapter: @@ -17,7 +17,7 @@ defmodule OpenApiSpex.Plug.Cache do like this in `dev.exs`: ```elixir - config :open_api_spex, :cache_adapter OpenApiSpex.Plug.NoneCache + config :open_api_spex, :cache_adapter, OpenApiSpex.Plug.NoneCache ``` """