14#include "Gaudi/Interfaces/IOptionsSvc.h"
15#include "GaudiKernel/GaudiException.h"
16#include "GaudiKernel/Guards.h"
17#include "GaudiKernel/IIncidentSvc.h"
18#include "GaudiKernel/IIoComponentMgr.h"
19#include "GaudiKernel/IOpaqueAddress.h"
20#include "GaudiKernel/IProperty.h"
40 :
public cool::IDatabase
43 LockedDatabase (cool::IDatabasePtr dbptr,
44 const Athena::DBLock& dblock)
45 : m_dbptr (std::move(dbptr)), m_dblock (dblock) {}
47 virtual ~LockedDatabase() =
default;
49 virtual const cool::DatabaseId& databaseId()
const override
50 {
return m_dbptr->databaseId(); }
52 virtual const cool::IRecord& databaseAttributes()
const override
53 {
return m_dbptr->databaseAttributes(); }
55 virtual cool::IFolderSetPtr createFolderSet
56 (
const std::string& fullPath,
58 bool createParents =
false )
override
59 {
return m_dbptr->createFolderSet (fullPath,
description, createParents); }
61 virtual bool existsFolderSet(
const std::string& folderSetName )
override
62 {
return m_dbptr->existsFolderSet (folderSetName); }
64 virtual cool::IFolderSetPtr getFolderSet(
const std::string& fullPath )
override
65 {
return m_dbptr->getFolderSet (fullPath); }
68 (
const std::string& fullPath,
69 const cool::IFolderSpecification& folderSpec,
71 bool createParents =
false )
override
72 {
return m_dbptr->createFolder (fullPath, folderSpec,
description, createParents); }
74 virtual bool existsFolder(
const std::string& fullPath )
override
75 {
return m_dbptr->existsFolder (fullPath); }
77 virtual cool::IFolderPtr getFolder(
const std::string& fullPath )
override
78 {
return m_dbptr->getFolder (fullPath); }
80 virtual const std::vector<std::string> listAllNodes(
bool ascending =
true )
override
81 {
return m_dbptr->listAllNodes (ascending); }
83 virtual bool dropNode(
const std::string& fullPath )
override
84 {
return m_dbptr->dropNode (fullPath); }
86 virtual bool existsTag(
const std::string& tagName )
const override
87 {
return m_dbptr->existsTag (tagName); }
89 virtual cool::IHvsNode::Type tagNameScope(
const std::string& tagName )
const override
90 {
return m_dbptr->tagNameScope (tagName); }
92 virtual const std::vector<std::string>
93 taggedNodes(
const std::string& tagName )
const override
94 {
return m_dbptr->taggedNodes (tagName); }
96 virtual bool isOpen()
const override
97 {
return m_dbptr->isOpen(); }
100 {
return m_dbptr->openDatabase(); }
102 virtual void closeDatabase()
override
103 {
return m_dbptr->closeDatabase(); }
105 virtual const std::string& databaseName()
const override
106 {
return m_dbptr->databaseName(); }
110 virtual ITransactionPtr startTransaction()
override
111 {
return m_dbptr->startTransaction(); }
116 cool::IDatabasePtr m_dbptr;
117 Athena::DBLock m_dblock;
133 ATH_MSG_INFO(
"Opened read transaction for POOL PersistencySvc");
136 ATH_MSG_INFO(
"Cannot connect to POOL PersistencySvc" );
147 const long int pri = 100;
148 incSvc->addListener(
this, IncidentType::BeginEvent, pri );
149 incSvc->addListener(
this,
"StoreCleared", pri );
150 incSvc->addListener(
this, IncidentType::EndProcessing, pri );
159 ATH_MSG_INFO(
"COOL connection management disabled - connections kept open throughout job" );
161 ATH_MSG_INFO(
"POOL file connection management disabled - files kept open throught job" );
176 ATH_MSG_INFO(
"Online mode ignoring potential missing channels outside cache" );
208 " connections and " <<
m_foldermap.size() <<
" folders" );
213 ATH_MSG_INFO(
"Service IOVDbSvc initialised successfully" );
216 return StatusCode::SUCCESS;
224 return StatusCode::SUCCESS;
230 return StatusCode::SUCCESS;
236 unsigned long long nread = 0;
240 std::map<IOVDbConn*, float> ctmap;
243 nread += folder->bytesRead();
244 readtime += folder->readTime();
245 const auto& [citr, inserted] = ctmap.try_emplace(folder->conn(), 0);
246 citr->second += folder->readTime();
249 ATH_MSG_INFO(
"Total payload read from IOVDb: " << nread <<
" bytes in (( " << std::fixed << std::setw(9) << std::setprecision(2) <<
250 readtime <<
" ))s" );
255 const auto citr = ctmap.find(conn.get());
256 if (citr != ctmap.end()) fread = citr->second;
258 conn->summary(fread);
262 return StatusCode::SUCCESS;
268 cool::IDatabasePtr dbconn;
270 ATH_MSG_INFO(
"No default COOL database connection is available");
275 ATH_MSG_INFO(
"Changing state of default connection to readonly=" << readOnly );
278 dbconn = std::make_shared<LockedDatabase> (
m_connections[0]->getCoolDb(),
297 unsigned int ncontainers=0;
298 unsigned int nused=0;
299 for (;cont!=contEnd; ++cont) {
301 const std::string& fname=cont->folderName();
305 if (folder->folderName()==fname && !(folder->tagOverride())) {
306 ATH_MSG_INFO(
"Folder " << fname <<
" will be taken from file metadata" );
307 folder->useFileMetaData();
308 folder->setFolderDescription( cont->folderDescription() );
314 ATH_MSG_INFO(
"Found " << ncontainers <<
" metadata containers in input file, " << nused <<
" will be used");
316 ATH_MSG_DEBUG(
"Could not retrieve IOVMetaDataContainer objects from MetaDataStore" );
325 std::vector<std::string> keysToDelete;
327 if (folder->fromMetaDataOnly() && !folder->readMeta()) {
328 ATH_MSG_INFO(
"preLoadAddresses: Removing folder " << folder->folderName() <<
329 ". It should only be in the file meta data and was not found." );
330 keysToDelete.push_back(name);
334 for (
auto & thisKey : keysToDelete) {
337 fitr->second->conn()->decUsage();
340 ATH_MSG_ERROR(
"preLoadAddresses: Could not find folder " << thisKey <<
" for removal" );
353 if (pThisConnection->nFolders()>0 || doMeta) {
356 if (folder->conn()==pThisConnection.get() || (folder->conn()==
nullptr && doMeta)) {
357 std::unique_ptr<SG::TransientAddress> tad =
359 if (oldconn!=pThisConnection.get()) {
362 oldconn=pThisConnection.get();
365 ATH_MSG_ERROR(
"preLoadFolder failed for folder " << folder->folderName() );
366 return StatusCode::FAILURE;
369 if (folder->writeMeta()) {
370 if (
m_h_IOVSvc->preLoadDataTAD(tad.get(),folder->eventStore()).isFailure()) {
371 ATH_MSG_ERROR(
"Could not request IOVSvc to preload metadata for " << folder->folderName() );
372 return StatusCode::FAILURE;
376 if (
m_h_IOVSvc->preLoadTAD(tad.get(), folder->eventStore()).isFailure()) {
377 ATH_MSG_ERROR(
"Could not request IOVSvc to preload metadata for " << folder->folderName() );
378 return StatusCode::FAILURE;
382 tlist.push_back(tad.release());
398 newmap[folder->key()]=std::move(folder);
404 ATH_MSG_ERROR(
"Could not fill TagInfo object from preLoadAddresses" );
406 return StatusCode::SUCCESS;
412 return StatusCode::SUCCESS;
417 const EventContext& )
423 Gaudi::Guards::AuditorGuard auditor(std::string(
"UpdateAddr::")+(tad->
name().empty() ?
"anonymous" : tad->
name()),
424 auditorSvc(),
"preLoadProxy");
428 std::unique_ptr<IOpaqueAddress> address;
433 const std::string& key=tad->
name();
437 "updateAddress cannot find description for TAD " << key );
438 return StatusCode::FAILURE;
440 const auto& folder=fitr->second;
441 if (folder->clid()!=tad->
clID()) {
443 <<
" but expecting " << folder->clid() );
445 return StatusCode::FAILURE;
451 ATH_MSG_DEBUG(
"updateAddress: in initialisation phase and no iovTime defined" );
452 return::StatusCode::SUCCESS;
458 iovTime.
setRunEvent( evid->run_number(), evid->lumi_block()) ;
460 uint64_t nsTime = evid->time_stamp() *1000000000LL;
461 nsTime += evid->time_stamp_ns_offset();
464 ATH_MSG_DEBUG(
"updateAddress - using iovTime from EventInfo: " << iovTime);
468 return StatusCode::SUCCESS;
471 ATH_MSG_DEBUG(
"updateAddress: using iovTime from init/beginRun: " << iovTime);
477 cool::ValidityKey vkey=folder->iovTime(iovTime);
489 if (!folder->readMeta() && !folder->cacheValid(vkey)) {
491 folder->setDropped(
false);
493 ATH_MSG_DEBUG(
"Triggering cache load for folder " << folder->folderName());
495 ATH_MSG_ERROR(
"Cache load failed for at least one folder from " << folder->conn()->name()
496 <<
". You may see errors from other folders sharing the same connection." );
497 return StatusCode::FAILURE;
504 Gaudi::Guards::AuditorGuard auditor(std::string(
"FldrSetup:")+(tad->
name().empty() ?
"anonymous" : tad->
name()),
505 auditorSvc(),
"preLoadProxy");
508 ATH_MSG_ERROR(
"getAddress failed for folder " << folder->folderName() );
509 return StatusCode::FAILURE;
514 if (folder->timeStamp()) {
515 cool::ValidityKey start=range.start().timestamp();
523 range,folder->eventStore()).isFailure()) {
524 ATH_MSG_ERROR(
"setRange failed for folder " << folder->folderName() );
525 return StatusCode::FAILURE;
528 return StatusCode::SUCCESS;
533 const std::string& dbKey,
537 std::unique_ptr<IOpaqueAddress>& address) {
541 ATH_MSG_DEBUG(
"getRange clid: " << clid <<
" key: \""<< dbKey <<
"\" t: " << time );
545 ATH_MSG_VERBOSE(
"getRange cannot find description for dbKey " << dbKey );
546 return StatusCode::FAILURE;
548 const auto& folder = fitr->second;
549 if (folder->clid()!=clid) {
552 <<
" but expecting " << folder->clid() );
554 return StatusCode::FAILURE;
560 cool::ValidityKey vkey=folder->iovTime(time);
561 if (!folder->readMeta() && !folder->cacheValid(vkey)) {
563 folder->setDropped(
false);
565 ATH_MSG_DEBUG(
"Triggering cache load for folder " << folder->folderName() );
566 if (
loadCaches(folder->conn(),&time).isFailure()) {
567 ATH_MSG_ERROR(
"Cache load failed for at least one folder from " << folder->conn()->name()
568 <<
". You may see errors from other folders sharing the same connection." );
569 return StatusCode::FAILURE;
577 Gaudi::Guards::AuditorGuard auditor(std::string(
"FldrSetup:")+(dbKey.empty() ?
"anonymous" : dbKey),
578 auditorSvc(),
"preLoadProxy");
581 ATH_MSG_ERROR(
"getAddress failed for folder " <<folder->folderName() );
582 return StatusCode::FAILURE;
587 if (folder->extensible()) {
589 IOVTime extStop = range.stop();
590 if (folder->timeStamp()) {
596 range =
IOVRange (range.start(), extStop);
600 if (folder->iovOverridden()) {
601 if (folder->timeStamp()) {
611 return StatusCode::SUCCESS;
618 const std::string& ) {
620 return StatusCode::SUCCESS;
625 const EventContext& ctx)
638 EventIDBase::number_type conditionsRun =
640 if (conditionsRun != EventIDBase::UNDEFNUM) {
646 return StatusCode::SUCCESS;
651 ATH_MSG_DEBUG(
"Same run as previous signalBeginRun call. Skipping re-loading of folders..." );
652 return StatusCode::SUCCESS;
664 static const std::string preLoadProxyStr{
"preLoadProxy"};
668 if (pThisConnection->nFolders()>0) {
670 cool::IDatabasePtr dbconn=pThisConnection->getCoolDb();
671 if (dbconn.get()==
nullptr) {
672 ATH_MSG_FATAL(
"Conditions database connection " << pThisConnection->name() <<
" cannot be opened - STOP" );
673 return StatusCode::FAILURE;
676 if (folder->conn()!=pThisConnection.get())
continue;
677 folder->printCache();
678 cool::ValidityKey vkey=folder->iovTime(
m_iovTime);
680 Gaudi::Guards::AuditorGuard auditor(std::string(
"FldrCache:")+folder->folderName(), auditorSvc(), preLoadProxyStr);
682 ATH_MSG_ERROR(
"Problem RELOADING: " << folder->folderName());
683 return StatusCode::FAILURE;
686 folder->printCache();
691 return StatusCode::SUCCESS;
711 ATH_MSG_DEBUG(
"Successfully closed input POOL connections");
717 ATH_MSG_DEBUG(
"Reopend read transaction for POOL conditions input files" );
719 ATH_MSG_WARNING(
"Cannot reopen read transaction for POOL conditions input files");
730 ATH_MSG_VERBOSE(
"entering handle(), incident type " << inc.type() <<
" from " << inc.source() );
731 if (inc.type()==
"BeginEvent") {
737 if( (inc.type()==
"StoreCleared" && sinc!=
nullptr && sinc->
store()==&*
m_h_sgSvc
739 or inc.type()==IncidentType::EndProcessing )
765 for (
const auto & [theTagName, theTag]: nameTagPairs) {
767 if (not theTagName.starts_with(
'/'))
continue;
770 const std::string& ifname=folder->folderName();
771 if (ifname!=theTagName)
continue;
775 if (folder->joTag().empty() && !folder->readMeta() && !folder->noOverride() &&
m_par_globalTag.empty()) {
776 folder->setTagOverride(theTag,
false);
777 ATH_MSG_INFO(
"TagInfo override for tag " << theTag <<
" in folder " << ifname );
778 }
else if (folder->joTag()!=theTag) {
779 const std::string_view tagTypeString=(folder->joTag().
empty()) ?
"hierarchical" :
"jobOption";
780 ATH_MSG_INFO(
"Ignoring inputfile TagInfo request for tag " << theTag <<
" in folder " << ifname<<
" in favour of "<<tagTypeString);
784 return StatusCode::SUCCESS;
788std::vector<std::string>
792 return {keys.begin(), keys.end()};
802 info.folderName = f->folderName();
803 info.tag = f->resolvedTag();
804 info.range = f->currentRange();
805 info.retrieved = f->retrieved();
806 info.bytesRead = f->bytesRead();
807 info.readTime = f->readTime();
808 info.extensible = f->extensible();
811 info.retrieved =
false;
822 CLID clid=folder->clid();
824 if (proxy!=
nullptr) {
827 folder->setDropped(
true);
829 folder->resetCache();
830 ATH_MSG_DEBUG(
"Cache reset done for folder " << folder->folderName() );
853 if (!joSvc->has(
"EventSelector.OverrideRunNumber")) {
856 ATH_MSG_DEBUG(
"No EventSelector.OverrideRunNumber property found" );
857 return StatusCode::SUCCESS;
860 BooleanProperty overrideRunNumber(
"OverrideRunNumber",
false);
861 ATH_CHECK( overrideRunNumber.fromString(joSvc->get(
"EventSelector.OverrideRunNumber")) );
862 if (overrideRunNumber) {
864 ATH_MSG_INFO(
"Setting run/LB/time from EventSelector override in initialize" );
871 IntegerProperty iprop1(
"RunNumber",0);
872 if (iprop1.fromString(joSvc->get(
"EventSelector.RunNumber",
"INVALID"))) {
875 ATH_MSG_ERROR(
"Unable to get RunNumber from EventSelector");
878 IntegerProperty iprop2(
"FirstLB",0);
879 if (iprop2.fromString(joSvc->get(
"EventSelector.FirstLB",
"INVALID"))) {
885 IntegerProperty iprop3(
"InitialTimeStamp",0);
886 if (iprop3.fromString(joSvc->get(
"EventSelector.InitialTimeStamp",
"INVALID"))) {
889 ATH_MSG_ERROR(
"Unable to get InitialTimeStamp from EventSelector" );
894 uint64_t nsTime=time*1000000000LL;
896 ATH_MSG_INFO(
"run/LB/time set to [" <<
run <<
"," << lumib <<
" : " << nsTime <<
"]" );
902 return StatusCode::SUCCESS;
917 std::list<IOVDbParser> allFolderdata;
922 ATH_MSG_FATAL(
"setupFolders: Folder setup string is invalid: " <<thisFolder);
923 return StatusCode::FAILURE;
926 allFolderdata.push_back(std::move(folderdata));
937 if (not keys.isValid()){
938 ATH_MSG_ERROR(
"An override tag was invalid: " << thisOverrideTag);
939 return StatusCode::FAILURE;
942 if (!keys.getKey(
"prefix",
"",prefix)) {
943 ATH_MSG_ERROR(
"Problem in overrideTag specification " <<thisOverrideTag );
944 return StatusCode::FAILURE;
947 for (
auto& folderdata : allFolderdata) {
948 const std::string& ifname=folderdata.folderName();
949 if (ifname.starts_with(prefix) &&
950 (ifname.size()==prefix.size() || ifname[prefix.size()]==
'/')) {
952 folderdata.applyOverrides(keys,
msg());
958 std::list<IOVDbParser>::iterator it1=allFolderdata.begin();
959 std::list<IOVDbParser>::iterator it_e=allFolderdata.end();
960 for (;it1!=it_e;++it1) {
962 std::list<IOVDbParser>::iterator it2=it1;
966 if (folder1==folder2) {
967 it2=allFolderdata.erase(it2);
968 ATH_MSG_DEBUG(
"Removing duplicate folder " << folder1.folderName());
972 if (folder1.folderName()==folder2.folderName()) {
973 ATH_MSG_WARNING(
"Folder name appears twice: " << folder1.folderName() );
982 bool crestError=
false;
983 for (
const auto& folderdata : allFolderdata) {
988 if (folderdata.getKey(
"db",
"",connstr) ||
989 folderdata.getKey(
"dbConnection",
"",connstr)) {
993 if (pThisConnection->name()==connstr) {
995 conn=pThisConnection.get();
1001 conn =
m_connections.emplace_back(std::make_unique<IOVDbConn>(connstr,
true,
msg())).get();
1008 ATH_MSG_FATAL(
"Folder request " << folderdata.folderName() <<
1009 " gives no DB connection information and no default set" );
1010 return StatusCode::FAILURE;
1017 std::string crestTag;
1020 if(crestTag.empty() && folderdata.folderName() !=
"/TagInfo") {
1022 << folderdata.folderName());
1031 const std::string& key=folder->key();
1037 folder->folderName() <<
1038 " associated to already requested Storegate key " << key );
1044 return StatusCode::FAILURE;
1049 std::string_view
match=folderToWrite;
1050 std::string::size_type idx=folderToWrite.find(
'*');
1051 if (idx!=std::string::npos) {
1052 match=std::string_view(folderToWrite).substr(0,idx);
1055 if (folder->folderName().starts_with(
match)) {
1056 folder->setWriteMeta();
1057 ATH_MSG_INFO(
"Folder " << folder->folderName() <<
" will be written to file metadata" );
1061 return StatusCode::SUCCESS;
1073 if (!folder->joTag().empty()) {
1074 ATH_MSG_DEBUG(
"Adding folder " << folder->folderName() <<
" tag " << folder->joTag() <<
" into TagInfo" );
1075 if (
m_h_tagInfoMgr->addTag(folder->folderName(),folder->joTag()).isFailure())
1076 return StatusCode::FAILURE;
1083 if (!
m_par_globalTag.empty() || !folder->joTag().empty() || folder->noOverride() ||
1084 folder->readMeta()) {
1085 if (
m_h_tagInfoMgr->removeTagFromInput(folder->folderName()).isFailure()) {
1087 << folder->folderName() );
1089 ATH_MSG_INFO(
"Added taginfo remove for " << folder->folderName() );
1093 return StatusCode::SUCCESS;
1101 Gaudi::Guards::AuditorGuard auditor(std::string(
"loadCachesOverhead:")+conn->name(), auditorSvc(),
"preLoadProxy");
1103 ATH_MSG_DEBUG(
"loadCaches: Begin for connection " << conn->name());
1105 if (
m_abort)
return StatusCode::FAILURE;
1107 StatusCode
sc=StatusCode::SUCCESS;
1109 if (folder->conn()!=conn)
continue;
1110 cool::ValidityKey vkey=folder->iovTime(time==
nullptr ?
m_iovTime : *time);
1112 if (vkey>cool::ValidityKeyMax) {
1113 ATH_MSG_WARNING(
"Requested validity key " << vkey <<
" is out of range, reset to 0" );
1116 if (!folder->cacheValid(vkey) && !folder->dropped()) {
1119 Gaudi::Guards::AuditorGuard auditor(std::string(
"FldrCache:")+folder->folderName(), auditorSvc(),
"preLoadProxy");
1121 ATH_MSG_ERROR(
"Cache load (prefetch) failed for folder " << folder->folderName() );
1124 sc=StatusCode::FAILURE;
1133 if (conn->aborted()) {
1135 throw GaudiException(
"Connection " + conn->name() +
" was aborted",
1136 "IOVDbSvc::loadCache()", StatusCode::FAILURE);
1149 const std::string_view tagstub = std::string_view(
m_globalTag).substr(0,7);
1153 (tagstub!=
"COMCOND" && tagstub!=
"CONDBR2")) ||
1154 (
m_par_dbinst==
"OFLP200" && (tagstub!=
"OFLCOND" && tagstub!=
"CMCCOND")) ) {
1156 ATH_MSG_FATAL(
"Likely incorrect conditions DB configuration! " <<
1158 " but global tag begins " << tagstub );
1160 " or set IOVDbSvc.DBInstance=\"\" to disable check" );
1161 return StatusCode::FAILURE;
1164 return StatusCode::SUCCESS;
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
Header for CoralCrestManager class.
const EventIDBase * EventIDFromStore(IProxyDict *store)
Retrieve the EventID from EventContext saved in store STORE.
uint32_t CLID
The Class ID type.
Athena service for Interval Of Validity database.
Incident sent after a store is cleared.
static const Attributes_t empty
Define macros for attributes used to control the static checker.
#define ATLAS_THREAD_SAFE
EventIDBase::number_type conditionsRun() const
static std::map< std::string, std::string > getGlobalTagMap(const std::string &crest_path, const std::string &globaltag)
virtual StatusCode finalize() override
Service finalize.
BooleanProperty m_par_managePoolConnections
StatusCode loadCaches(IOVDbConn *conn, const IOVTime *time=nullptr)
PublicToolHandle< IIOVDbMetaDataTool > m_h_metaDataTool
ServiceHandle< StoreGateSvc > m_h_sgSvc
Gaudi::Property< std::vector< std::string > > m_par_overrideTags
virtual void handle(const Incident &incident) override
Incident service handle for EndEvent.
Gaudi::Property< std::vector< std::string > > m_par_folders
virtual cool::IDatabasePtr getDatabase(bool readOnly) override
Access to COOL database for a given folder.
BooleanProperty m_crestCoolToFile
virtual bool dropObject(const std::string &key, const bool resetCache=false) override
IAddressProvider::tadList tadList
BooleanProperty m_outputToFile
BooleanProperty m_par_checklock
IntegerProperty m_par_forceLumiblockNumber
BooleanProperty m_par_manageConnections
virtual StatusCode preLoadAddresses(StoreID::type storeID, tadList &list) override
Get all addresses that the provider wants to preload in SG maps.
StatusCode io_finalize() override final
ServiceHandle< IAddressCreator > m_h_persSvc
std::map< std::string, std::string > m_cresttagmap
StatusCode checkConfigConsistency() const
IntegerProperty m_par_maxNumPoolFiles
UnsignedIntegerProperty m_par_cacheAlign
StatusCode io_reinit() override final
IntegerProperty m_par_forceTimestamp
virtual StatusCode setRange(const CLID &clid, const std::string &dbKey, const IOVRange &range, const std::string &tag) override
Set range for a particular data object.
IntegerProperty m_par_cacheRun
virtual StatusCode initialize() override
Service init.
StatusCode checkEventSel()
virtual void postConditionsLoad() override
May be called once conditions are loaded to let IOVDbSvc release resources.
BooleanProperty m_par_onlineMode
ServiceHandle< StoreGateSvc > m_h_metaDataStore
ServiceHandle< IClassIDSvc > m_h_clidSvc
ServiceHandle< ITagInfoMgr > m_h_tagInfoMgr
Gaudi::Property< std::string > m_par_dbinst
virtual StatusCode signalBeginRun(const IOVTime &beginRunTime, const EventContext &ctx) override
Set time for begin run.
ServiceHandle< IPoolSvc > m_h_poolSvc
bool m_poolPayloadRequested
StatusCode setupFolders()
ServiceHandle< StoreGateSvc > m_h_detStore
virtual bool getKeyInfo(const std::string &key, IIOVDbSvc::KeyInfo &info) override
Return information about SG key return false if this key is not known to IOVDbSvc.
Gaudi::Property< std::string > m_par_defaultConnection
virtual StatusCode loadAddresses(StoreID::type storeID, tadList &list) override
Get all new addresses from Provider for this Event.
virtual StatusCode updateAddress(StoreID::type storeID, SG::TransientAddress *tad, const EventContext &ctx) override
Update a transient Address.
virtual std::vector< std::string > getKeyList() override
virtual void signalEndProxyPreload() override
Signal that callback has been fired.
IntegerProperty m_par_cacheTime
Gaudi::Property< std::vector< std::string > > m_par_foldersToWrite
Gaudi::Property< std::string > m_par_globalTag
IntegerProperty m_par_forceRunNumber
StringProperty m_par_crestServer
virtual StatusCode processTagInfo() override
Process TagInfo.
StringProperty m_par_source
virtual StatusCode getRange(const CLID &clid, const std::string &dbKey, const IOVTime &time, IOVRange &range, std::string &tag, std::unique_ptr< IOpaqueAddress > &ioa) override
Get range for a particular data object identified by its clid and key and a requested IOVTime.
FloatProperty m_par_timeStampSlop
cool::ValidityKey m_iovslop
std::vector< std::unique_ptr< IOVDbConn > > m_connections
std::map< std::string, std::unique_ptr< IOVDbFolder > > FolderMap
ServiceHandle< IIOVSvc > m_h_IOVSvc
Basic time unit for IOVSvc.
static constexpr uint64_t MAXTIMESTAMP
static constexpr uint32_t MAXRUN
void setRETime(uint64_t time) noexcept
void setRunEvent(uint32_t run, uint32_t event) noexcept
static constexpr uint32_t MINEVENT
static constexpr uint64_t MINTIMESTAMP
void setTimestamp(uint64_t timestamp) noexcept
uint32_t run() const noexcept
static constexpr uint32_t MAXEVENT
static constexpr uint32_t MINRUN
std::vector< NameTagPair > NameTagPairVec
a const_iterator facade to DataHandle.
CLID clID() const
Retrieve string key:
const std::string & name() const
Get the primary (hashed) SG key.
void setAddress(CxxUtils::RefCountedPtr< IOpaqueAddress > pAddress)
Retrieve primary clid.
Incident sent after a store is cleared.
const StoreGateSvc * store() const
Return the store that was cleared.
void commit()
Save catalog to file.
std::string description
glabal timer - how long have I taken so far?
bool match(std::string s1, std::string s2)
match the individual directories of two strings
const ExtendedEventContext & getExtendedEventContext(const EventContext &ctx)
Retrieve an extended context from a context object.
Filled by IIOVDbSvc::getKeyInfo.
int run(int argc, char *argv[])