mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-22 18:43:02 +01:00
remove redundant plugin reload on super server, update it only on classic after stateLock ast (#8393)
Co-authored-by: aleksey.mochalov <aleksey.mochalov@red-soft.ru>
This commit is contained in:
parent
45011a9316
commit
190545ef19
@ -368,7 +368,7 @@ namespace Jrd {
|
||||
return;
|
||||
|
||||
fb_assert(tdbb);
|
||||
lockAndReadHeader(tdbb, CRYPT_HDR_NOWAIT);
|
||||
lockAndReadHeader(tdbb, CRYPT_HDR_NOWAIT | CRYPT_RELOAD_PLUGIN);
|
||||
}
|
||||
|
||||
void CryptoManager::lockAndReadHeader(thread_db* tdbb, unsigned flags)
|
||||
@ -407,9 +407,15 @@ namespace Jrd {
|
||||
crypt = hdr->hdr_flags & Ods::hdr_encrypted;
|
||||
process = hdr->hdr_flags & Ods::hdr_crypt_process;
|
||||
|
||||
if (flags & CRYPT_RELOAD_PLUGIN && cryptPlugin)
|
||||
{
|
||||
PluginManagerInterfacePtr()->releasePlugin(cryptPlugin);
|
||||
cryptPlugin = NULL;
|
||||
}
|
||||
|
||||
// tdbb w/o attachment comes when database is shutting down in the end of detachDatabase()
|
||||
// the only needed here page is header, i.e. we can live w/o cryptPlugin
|
||||
if ((crypt || process) && tdbb->getAttachment())
|
||||
if ((crypt || process) && !cryptPlugin && tdbb->getAttachment())
|
||||
{
|
||||
ClumpletWriter hc(ClumpletWriter::UnTagged, hdr->hdr_page_size);
|
||||
hdr.getClumplets(hc);
|
||||
@ -418,8 +424,6 @@ namespace Jrd {
|
||||
else
|
||||
keyName = "";
|
||||
|
||||
if (!cryptPlugin)
|
||||
{
|
||||
loadPlugin(tdbb, hdr->hdr_crypt_plugin);
|
||||
pluginName = hdr->hdr_crypt_plugin;
|
||||
string valid;
|
||||
@ -433,42 +437,6 @@ namespace Jrd {
|
||||
else
|
||||
hash = valid;
|
||||
}
|
||||
else
|
||||
{
|
||||
for (GetPlugins<IKeyHolderPlugin> keyControl(IPluginManager::TYPE_KEY_HOLDER, dbb.dbb_config);
|
||||
keyControl.hasData(); keyControl.next())
|
||||
{
|
||||
// check does keyHolder want to provide a key for us
|
||||
IKeyHolderPlugin* keyHolder = keyControl.plugin();
|
||||
|
||||
FbLocalStatus st;
|
||||
int keyCallbackRc = keyHolder->keyCallback(&st, tdbb->getAttachment()->att_crypt_callback);
|
||||
st.check();
|
||||
if (!keyCallbackRc)
|
||||
continue;
|
||||
|
||||
// validate a key
|
||||
AutoPlugin<IDbCryptPlugin> crypt(checkFactory->makeInstance());
|
||||
setDbInfo(crypt);
|
||||
crypt->setKey(&st, 1, &keyHolder, keyName.c_str());
|
||||
|
||||
|
||||
string valid;
|
||||
calcValidation(valid, crypt);
|
||||
if (hc.find(Ods::HDR_crypt_hash))
|
||||
{
|
||||
hc.getString(hash);
|
||||
if (hash == valid)
|
||||
{
|
||||
// unload old plugin and set new one
|
||||
PluginManagerInterfacePtr()->releasePlugin(cryptPlugin);
|
||||
cryptPlugin = NULL;
|
||||
cryptPlugin = crypt.release();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (cryptPlugin && (flags & CRYPT_HDR_INIT))
|
||||
checkDigitalSignature(tdbb, hdr);
|
||||
|
@ -364,6 +364,7 @@ private:
|
||||
void lockAndReadHeader(thread_db* tdbb, unsigned flags = 0);
|
||||
static const unsigned CRYPT_HDR_INIT = 0x01;
|
||||
static const unsigned CRYPT_HDR_NOWAIT = 0x02;
|
||||
static const unsigned CRYPT_RELOAD_PLUGIN = 0x04;
|
||||
|
||||
void addClumplet(Firebird::string& value, Firebird::ClumpletReader& block, UCHAR tag);
|
||||
void calcDigitalSignature(thread_db* tdbb, Firebird::string& signature, const class Header& hdr);
|
||||
|
Loading…
Reference in New Issue
Block a user