From 85e5b9b7400348887e1596ba0dbc501c48766d52 Mon Sep 17 00:00:00 2001 From: hvlad Date: Wed, 17 Jun 2020 17:19:38 +0300 Subject: [PATCH] Fixed one more case of bug CORE-5087 : Database shutdown can cause server crash if multiple attachments run EXECUTE STATEMENT --- src/jrd/extds/InternalDS.cpp | 71 ++++++++++++++++++------------------ 1 file changed, 36 insertions(+), 35 deletions(-) diff --git a/src/jrd/extds/InternalDS.cpp b/src/jrd/extds/InternalDS.cpp index 339a5913c1..be98e9d21d 100644 --- a/src/jrd/extds/InternalDS.cpp +++ b/src/jrd/extds/InternalDS.cpp @@ -397,47 +397,48 @@ void InternalStatement::doPrepare(thread_db* tdbb, const string& sql) fb_assert(!m_allocated); } + CallerName save_caller_name(tran->getHandle()->tra_caller_name); + + if (m_callerPrivileges) + { + jrd_req* request = tdbb->getRequest(); + JrdStatement* statement = request ? request->getStatement() : NULL; + CallerName callerName; + const Routine* routine; + + if (statement && statement->parentStatement) + statement = statement->parentStatement; + + if (statement && statement->triggerName.hasData()) + tran->getHandle()->tra_caller_name = CallerName(obj_trigger, statement->triggerName); + else if (statement && (routine = statement->getRoutine()) && + routine->getName().identifier.hasData()) + { + if (routine->getName().package.isEmpty()) + { + tran->getHandle()->tra_caller_name = CallerName(routine->getObjectType(), + routine->getName().identifier); + } + else + { + tran->getHandle()->tra_caller_name = CallerName(obj_package_header, + routine->getName().package); + } + } + else + tran->getHandle()->tra_caller_name = CallerName(); + } + { EngineCallbackGuard guard(tdbb, *this, FB_FUNCTION); - CallerName save_caller_name(tran->getHandle()->tra_caller_name); - - if (m_callerPrivileges) - { - jrd_req* request = tdbb->getRequest(); - JrdStatement* statement = request ? request->getStatement() : NULL; - CallerName callerName; - const Routine* routine; - - if (statement && statement->parentStatement) - statement = statement->parentStatement; - - if (statement && statement->triggerName.hasData()) - tran->getHandle()->tra_caller_name = CallerName(obj_trigger, statement->triggerName); - else if (statement && (routine = statement->getRoutine()) && - routine->getName().identifier.hasData()) - { - if (routine->getName().package.isEmpty()) - { - tran->getHandle()->tra_caller_name = CallerName(routine->getObjectType(), - routine->getName().identifier); - } - else - { - tran->getHandle()->tra_caller_name = CallerName(obj_package_header, - routine->getName().package); - } - } - else - tran->getHandle()->tra_caller_name = CallerName(); - } - m_request.assignRefNoIncr(att->prepare(&status, tran, sql.length(), sql.c_str(), m_connection.getSqlDialect(), 0)); - m_allocated = (m_request != NULL); - - tran->getHandle()->tra_caller_name = save_caller_name; } + m_allocated = (m_request != NULL); + + if (tran->getHandle()) + tran->getHandle()->tra_caller_name = save_caller_name; if (status->getState() & IStatus::STATE_ERRORS) raise(&status, tdbb, "JAttachment::prepare", &sql);