refactor: authz_api_settings refactor with hoconsc
This commit is contained in:
parent
ff68e2a20f
commit
eaa659f2a1
|
@ -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], #{})).
|
||||||
|
|
Loading…
Reference in New Issue