refactor: authz_api_settings refactor with hoconsc

This commit is contained in:
JimMoen 2022-02-21 11:37:30 +08:00
parent ff68e2a20f
commit eaa659f2a1
1 changed files with 34 additions and 21 deletions

View File

@ -18,35 +18,45 @@
-behaviour(minirest_api). -behaviour(minirest_api).
-import(hoconsc, [mk/1, ref/2]).
-export([ api_spec/0 -export([ api_spec/0
, settings/2 , paths/0
, schema/1
]). ]).
-export([settings/2]).
-define(BAD_REQUEST, 'BAD_REQUEST').
api_spec() -> api_spec() ->
{[settings_api()], []}. emqx_dashboard_swagger:spec(?MODULE, #{check_schema => true}).
authorization_settings() -> paths() ->
maps:remove(<<"sources">>, emqx:get_raw_config([authorization], #{})). ["/authorization/settings"].
conf_schema() -> %%--------------------------------------------------------------------
emqx_mgmt_api_configs:gen_schema(authorization_settings()). %% Schema for each URI
%%--------------------------------------------------------------------
settings_api() -> schema("/authorization/settings") ->
Metadata = #{ #{ 'operationId' => settings
get => #{ , get =>
description => "Get authorization settings", #{ description => <<"Get authorization settings">>
responses => #{<<"200">> => emqx_mgmt_util:schema(conf_schema())} , responses =>
}, #{200 => ref_authz_schema()}
put => #{
description => "Update authorization settings",
requestBody => emqx_mgmt_util:schema(conf_schema()),
responses => #{
<<"200">> => emqx_mgmt_util:schema(conf_schema()),
<<"400">> => emqx_mgmt_util:bad_request()
} }
} , put =>
}, #{ description => <<"Update authorization settings">>
{"/authorization/settings", Metadata, settings}. , 'requestBody' => ref_authz_schema()
, responses =>
#{ 200 => ref_authz_schema()
, 400 => emqx_dashboard_swagger:error_codes([?BAD_REQUEST], <<"Bad Request">>)}
}
}.
ref_authz_schema() ->
proplists:delete(sources, emqx_conf_schema:fields("authorization")).
settings(get, _Params) -> settings(get, _Params) ->
{200, authorization_settings()}; {200, authorization_settings()};
@ -60,3 +70,6 @@ settings(put, #{body := #{<<"no_match">> := NoMatch,
{ok, _} = emqx_authz_utils:update_config([authorization, cache], Cache), {ok, _} = emqx_authz_utils:update_config([authorization, cache], Cache),
ok = emqx_authz_cache:drain_cache(), ok = emqx_authz_cache:drain_cache(),
{200, authorization_settings()}. {200, authorization_settings()}.
authorization_settings() ->
maps:remove(<<"sources">>, emqx:get_raw_config([authorization], #{})).