diff options
author | Alexey Shchepin <alexey@process-one.net> | 2019-03-07 22:14:13 +0300 |
---|---|---|
committer | Alexey Shchepin <alexey@process-one.net> | 2019-03-07 22:14:13 +0300 |
commit | e921b43754ec7b30ad2d23b316651b1b36b05178 (patch) | |
tree | d40f4dfc0bbe280a409f5c43d87b370d60602101 /src | |
parent | Handle 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.erl | 2 |
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; |