aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlexey Shchepin <alexey@process-one.net>2019-03-07 22:14:13 +0300
committerAlexey Shchepin <alexey@process-one.net>2019-03-07 22:14:13 +0300
commite921b43754ec7b30ad2d23b316651b1b36b05178 (patch)
treed40f4dfc0bbe280a409f5c43d87b370d60602101 /src
parentHandle info log level when using MySQL (#2541) (diff)
Fix transaction aborting and restarting in ejabberd_sql
Diffstat (limited to 'src')
-rw-r--r--src/ejabberd_sql.erl2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/ejabberd_sql.erl b/src/ejabberd_sql.erl
index c891e7aa8..a02aece4d 100644
--- a/src/ejabberd_sql.erl
+++ b/src/ejabberd_sql.erl
@@ -524,6 +524,7 @@ outer_transaction(F, NRestarts, _Reason) ->
catch
?EX_RULE(throw, {aborted, Reason}, _) when NRestarts > 0 ->
sql_query_internal([<<"rollback;">>]),
+ put(?NESTING_KEY, ?TOP_LEVEL_TXN),
outer_transaction(F, NRestarts - 1, Reason);
?EX_RULE(throw, {aborted, Reason}, Stack) when NRestarts =:= 0 ->
?ERROR_MSG("SQL transaction restarts exceeded~n** "
@@ -610,6 +611,7 @@ sql_query_internal(#sql_query{} = Query) ->
check_error(Res, Query);
sql_query_internal(F) when is_function(F) ->
case catch execute_fun(F) of
+ {aborted, Reason} -> {error, Reason};
{'EXIT', Reason} -> {error, Reason};
Res -> Res
end;