summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/rabbit_mirror_queue_misc.erl2
-rw-r--r--src/rabbit_policy.erl27
2 files changed, 15 insertions, 14 deletions
diff --git a/src/rabbit_mirror_queue_misc.erl b/src/rabbit_mirror_queue_misc.erl
index f596e404..6976dbbc 100644
--- a/src/rabbit_mirror_queue_misc.erl
+++ b/src/rabbit_mirror_queue_misc.erl
@@ -27,7 +27,7 @@
-include("rabbit.hrl").
-rabbit_boot_step({?MODULE,
- [{description, "HA policy validation capability"},
+ [{description, "HA policy validation"},
{mfa, {rabbit_registry, register,
[policy_validator, <<"ha-mode">>, ?MODULE]}},
{mfa, {rabbit_registry, register,
diff --git a/src/rabbit_policy.erl b/src/rabbit_policy.erl
index 3e7472cc..c938d1be 100644
--- a/src/rabbit_policy.erl
+++ b/src/rabbit_policy.erl
@@ -218,13 +218,12 @@ policy_validation() ->
validation(_Name, []) ->
{error, "no policy provided", []};
validation(_Name, Terms) when is_list(Terms) ->
- {Tags, Modules} = lists:unzip(
- rabbit_registry:lookup_all(policy_validator)),
- [] = lists:usort(Tags -- lists:usort(Tags)), %% ASSERTION
- Validators = lists:zipwith(fun (M, T) -> {M, a2b(T)} end, Modules, Tags),
-
+ {Keys, Modules} = lists:unzip(
+ rabbit_registry:lookup_all(policy_validator)),
+ [] = dups(Keys), %% ASSERTION
+ Validators = lists:zipwith(fun (M, K) -> {M, a2b(K)} end, Modules, Keys),
{TermKeys, _} = lists:unzip(Terms),
- case TermKeys -- lists:usort(TermKeys) of
+ case dups(TermKeys) of
[] -> validation0(Validators, Terms);
Dup -> {error, "~p duplicate keys not allowed", [Dup]}
end;
@@ -233,15 +232,15 @@ validation(_Name, Term) ->
validation0(Validators, Terms) ->
case lists:foldl(
- fun (_, {Error, _} = Acc) when Error /= ok ->
- Acc;
- (Mod, {ok, TermsLeft}) ->
- ModTags = proplists:get_all_values(Mod, Validators),
- case [T || {Tag, _} = T <- TermsLeft,
- lists:member(Tag, ModTags)] of
+ fun (Mod, {ok, TermsLeft}) ->
+ ModKeys = proplists:get_all_values(Mod, Validators),
+ case [T || {Key, _} = T <- TermsLeft,
+ lists:member(Key, ModKeys)] of
[] -> {ok, TermsLeft};
Scope -> {Mod:validate_policy(Scope), TermsLeft -- Scope}
- end
+ end;
+ (_, Acc) ->
+ Acc
end, {ok, Terms}, proplists:get_keys(Validators)) of
{ok, []} ->
ok;
@@ -252,3 +251,5 @@ validation0(Validators, Terms) ->
end.
a2b(A) -> list_to_binary(atom_to_list(A)).
+
+dups(L) -> L -- lists:usort(L).