// ----------------------------------------------------------------------
// File: SharedHashProvider.cc
// Author: Georgios Bitzes - CERN
// ----------------------------------------------------------------------
/************************************************************************
* EOS - the CERN Disk Storage System *
* Copyright (C) 2019 CERN/Switzerland *
* *
* This program is free software: you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation, either version 3 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program. If not, see .*
************************************************************************/
#include "mq/SharedHashProvider.hh"
#include "mq/LocalHash.hh"
#include "common/Locators.hh"
#include "qclient/QClient.hh"
#include "qclient/shared/SharedHash.hh"
#include "qclient/shared/SharedManager.hh"
EOSMQNAMESPACE_BEGIN
//------------------------------------------------------------------------------
// Constructor
//------------------------------------------------------------------------------
SharedHashProvider::SharedHashProvider(qclient::SharedManager* manager)
: mSharedManager(manager) {}
//------------------------------------------------------------------------------
// Get shared hash
//------------------------------------------------------------------------------
std::shared_ptr
SharedHashProvider::Get(const eos::common::SharedHashLocator& locator)
{
const std::string& key = locator.getQDBKey();
std::unique_lock lock(mMutex);
auto it = mStore.find(key);
if (it != mStore.end()) {
return it->second;
}
using eos::common::SharedHashLocator;
std::shared_ptr hash;
if ((locator.getType() == SharedHashLocator::Type::kSpace) ||
((locator.getType() == SharedHashLocator::Type::kGroup))) {
hash.reset(new LocalHash(key));
} else {
hash.reset(new qclient::SharedHash(mSharedManager, key));
}
mStore[key] = hash;
return hash;
}
//------------------------------------------------------------------------------
// Delete shared hash
//------------------------------------------------------------------------------
void
SharedHashProvider::Delete(const eos::common::SharedHashLocator& locator)
{
const std::string qdb_key = locator.getQDBKey();
std::unique_lock lock(mMutex);
auto it = mStore.find(qdb_key);
if (it != mStore.end()) {
mStore.erase(it);
}
qclient::QClient* qcl = mSharedManager->getQClient();
if (qcl) {
qcl->exec("DEL", qdb_key);
}
}
EOSMQNAMESPACE_END