diff options
| author | Simon MacMullen <simon@rabbitmq.com> | 2011-04-05 13:27:17 +0100 |
|---|---|---|
| committer | Simon MacMullen <simon@rabbitmq.com> | 2011-04-05 13:27:17 +0100 |
| commit | 4a5bf947506e1ceb901b4762ede747351314e60b (patch) | |
| tree | 4ccb9e95d201779227737a2dff5c5e1a1b1c3cbb /src | |
| parent | eed614baf27f1df28ebd6298949e7807c18f7095 (diff) | |
| download | rabbitmq-server-git-4a5bf947506e1ceb901b4762ede747351314e60b.tar.gz | |
Recover and invoke callbacks for bindings in the same Tx.
Diffstat (limited to 'src')
| -rw-r--r-- | src/rabbit_binding.erl | 46 |
1 files changed, 25 insertions, 21 deletions
diff --git a/src/rabbit_binding.erl b/src/rabbit_binding.erl index 563fc0cf64..7c49277884 100644 --- a/src/rabbit_binding.erl +++ b/src/rabbit_binding.erl @@ -95,32 +95,29 @@ routing_key, arguments]). recover(XNames, QNames) -> - XNameSet = sets:from_list(XNames), - QNameSet = sets:from_list(QNames), XBs = rabbit_misc:execute_mnesia_transaction( fun () -> - lists:foldl( - fun (Route = #route{ - binding = B = #binding{source = Src}}, Acc) -> - case should_recover(B, XNameSet, QNameSet) of - true -> ok = sync_transient_binding( - Route, fun mnesia:write/3), - rabbit_misc:dict_cons(Src, B, Acc); - false -> Acc - end - end, dict:new(), - mnesia:select(rabbit_durable_route, [{'$1', [], ['$1']}])) + XBs = recover_internal(XNames, QNames), + callback_bindings(true, XBs), + XBs end), - rabbit_misc:execute_pre_post_mnesia_tx( - fun (Tx) -> - dict:map(fun (XName, Bindings) -> - {ok, X} = rabbit_exchange:lookup(XName), - rabbit_exchange:callback(X, add_bindings, - [Tx, X, Bindings]) - end, XBs) - end), + callback_bindings(false, XBs), ok. +recover_internal(XNames, QNames) -> + XNameSet = sets:from_list(XNames), + QNameSet = sets:from_list(QNames), + lists:foldl( + fun (Route = #route{binding = B = #binding{source = Src}}, Acc) -> + case should_recover(B, XNameSet, QNameSet) of + true -> ok = sync_transient_binding( + Route, fun mnesia:write/3), + rabbit_misc:dict_cons(Src, B, Acc); + false -> Acc + end + end, dict:new(), + mnesia:select(rabbit_durable_route, [{'$1', [], ['$1']}])). + should_recover(B = #binding{destination = Dst = #resource{ kind = Kind }}, XNameSet, QNameSet) -> case mnesia:read({rabbit_route, B}) of @@ -131,6 +128,13 @@ should_recover(B = #binding{destination = Dst = #resource{ kind = Kind }}, _ -> false end. +callback_bindings(Tx, XBs) -> + dict:map(fun (XName, Bindings) -> + {ok, X} = rabbit_exchange:lookup(XName), + rabbit_exchange:callback(X, add_bindings, + [Tx, X, Bindings]) + end, XBs). + exists(Binding) -> binding_action( Binding, fun (_Src, _Dst, B) -> |
