10 #include <openssl/sha.h> 14 #include "RelationalAccess/ITransaction.h" 15 #include "RelationalAccess/ISessionProxy.h" 16 #include "RelationalAccess/ISchema.h" 17 #include "RelationalAccess/ITable.h" 18 #include "RelationalAccess/IQuery.h" 19 #include "RelationalAccess/ICursor.h" 20 #include "RelationalAccess/ITableDataEditor.h" 21 #include "RelationalAccess/TableDescription.h" 22 #include "CoralBase/Attribute.h" 23 #include "CoralBase/AttributeList.h" 24 #include "CoralBase/TimeStamp.h" 28 template <
typename SiStripPayload>
57 template<
typename SiStripPayload>
64 m_since( iConfig.getParameter< uint32_t >(
"since") ),
65 p_type(
cond::demangledName(typeid(SiStripPayload)) ),
68 if (iConfig.
exists(
"configMapDatabase"))
70 if (iConfig.
exists(
"cfgMapDbFile"))
76 template<
typename SiStripPayload>
80 template<
typename SiStripPayload>
91 std::shared_ptr<SiStripPayload> payloadToUpload;
96 bool mapUpToDate =
false;
98 if ( !mappedPayloadHash.empty() ){
102 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 103 <<
"Try retrieving payload from " <<
m_condDb;
104 payloadToUpload = condDbSession.
fetchPayload<SiStripPayload>( mappedPayloadHash );
105 std::cout <<
"@@@[FastO2O:true]@@@" << std::endl;
106 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 107 <<
" ... Payload is copied from offline condition database.";
110 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 111 <<
"NO mapping payload hash found. Will run the long O2O. ";
112 SiStripPayload *
obj =
nullptr;
118 payloadToUpload = std::shared_ptr<SiStripPayload>(
obj);
119 std::cout <<
"@@@[FastO2O:false]@@@" << std::endl;
120 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 121 <<
" ... New payload has been created.";
126 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 138 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 139 <<
"Payload " << thePayloadHash <<
" inserted to sqlite with IOV " <<
m_since;
147 if (last_hash == thePayloadHash){
148 std::cout <<
"@@@[PayloadChange:false]@@@" << last_hash << std::endl;
150 std::cout <<
"@@@[PayloadChange:true]@@@" << last_hash <<
" -> " << thePayloadHash << std::endl;
155 template<
typename SiStripPayload>
159 template<
typename SiStripPayload>
162 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 163 <<
"Convert config string to SHA-1 hash for " <<
p_type 169 if( !SHA1_Init( &ctx ) ){
172 if( !SHA1_Update( &ctx,
p_type.c_str(),
p_type.size() ) ){
175 if( !SHA1_Update( &ctx, p_cfgstr.c_str(), p_cfgstr.size() ) ){
178 unsigned char hash[SHA_DIGEST_LENGTH];
179 if( !SHA1_Final(hash, &ctx) ){
183 char tmp[SHA_DIGEST_LENGTH*2+1];
185 for (
unsigned int i = 0;
i < SHA_DIGEST_LENGTH;
i++) {
186 ::sprintf(&tmp[
i * 2],
"%02x", hash[i]);
188 tmp[SHA_DIGEST_LENGTH*2] = 0;
190 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 196 template<
typename SiStripPayload>
200 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 201 <<
"Query " <<
m_configMapDb <<
" to see if the payload is already in DB.";
205 cmDbSession->transaction().start(
true );
206 coral::ITable& cmTable = cmDbSession->nominalSchema().tableHandle(
m_cfgMapTableName );
207 std::unique_ptr<coral::IQuery>
query( cmTable.newQuery() );
208 query->addToOutputList(
"PAYLOAD_HASH" );
209 query->defineOutputType(
"PAYLOAD_HASH", coral::AttributeSpecification::typeNameForType<std::string>() );
211 query->addToOutputList(
"PAYLOAD_TYPE" );
212 query->addToOutputList(
"CONFIG_STRING" );
213 query->addToOutputList(
"INSERTION_TIME" );
214 std::string whereClause(
"CONFIG_HASH = :CONFIG_HASH" );
215 coral::AttributeList whereData;
217 whereData.begin()->data<
std::string >() = configHash;
218 query->setCondition( whereClause, whereData );
219 coral::ICursor& cursor =
query->execute();
223 p_hash = cursor.currentRow()[
"PAYLOAD_HASH"].data<
std::string>();
224 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 225 <<
"Found associated payload hash " << p_hash
226 <<
"\n... type=" << cursor.currentRow()[
"PAYLOAD_TYPE"].data<
std::string>()
227 <<
"\n... config=" << cursor.currentRow()[
"CONFIG_STRING"].data<
std::string>()
228 <<
"\n... insertion_time=" << cursor.currentRow()[
"INSERTION_TIME"].data<coral::TimeStamp>().
toString();
230 cmDbSession->transaction().commit();
235 template<
typename SiStripPayload>
239 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 240 <<
"Updating the config to payload hash map to " <<
m_cfgMapDbFile;
244 cmSQLiteSession->transaction().start(
false );
248 coral::TableDescription mapTable;
250 mapTable.insertColumn(
"CONFIG_HASH", coral::AttributeSpecification::typeNameForType<std::string>());
251 mapTable.insertColumn(
"PAYLOAD_HASH", coral::AttributeSpecification::typeNameForType<std::string>());
252 mapTable.insertColumn(
"PAYLOAD_TYPE", coral::AttributeSpecification::typeNameForType<std::string>());
253 mapTable.insertColumn(
"CONFIG_STRING", coral::AttributeSpecification::typeNameForType<std::string>());
254 mapTable.insertColumn(
"INSERTION_TIME", coral::AttributeSpecification::typeNameForType<coral::TimeStamp>());
255 mapTable.setPrimaryKey(
"CONFIG_HASH");
256 mapTable.setNotNullConstraint(
"CONFIG_HASH");
257 mapTable.setNotNullConstraint(
"PAYLOAD_HASH");
258 mapTable.setNotNullConstraint(
"PAYLOAD_TYPE");
259 mapTable.setNotNullConstraint(
"CONFIG_STRING");
260 mapTable.setNotNullConstraint(
"INSERTION_TIME");
261 cmSQLiteSession->nominalSchema().createTable(mapTable);
264 coral::ITable& cmTable = cmSQLiteSession->nominalSchema().tableHandle(
m_cfgMapTableName );
265 coral::AttributeList insertData;
271 insertData.extend<coral::TimeStamp>(
"INSERTION_TIME" );
272 insertData[
"CONFIG_HASH"].data<
std::string>() = configHash;
273 insertData[
"PAYLOAD_HASH"].data<
std::string>() = payloadHash;
277 cmTable.dataEditor().insertRow( insertData );
278 cmSQLiteSession->transaction().commit();
279 edm::LogInfo(
"SiStripPayloadHandler") <<
"[SiStripPayloadHandler::" << __func__ <<
"] " 280 <<
"Updated with mapping (configHash : payloadHash)" << configHash <<
" : " << payloadHash;
T getParameter(std::string const &) const
edm::Service< SiStripCondObjBuilderFromDb > condObjBuilder
SiStripPayloadHandler< SiStripNoises > SiStripO2ONoises
SiStripPayloadHandler< SiStripFedCabling > SiStripO2OFedCabling
std::string queryConfigMap(std::string configHash)
#define DEFINE_FWK_MODULE(type)
std::string m_cfgMapTableName
void start(bool readOnly=true)
bool exists(std::string const ¶meterName) const
checks if a parameter exists
void updateConfigMap(std::string configHash, std::string payloadHash)
IOVEditor createIov(const std::string &tag, cond::TimeType timeType, cond::SynchronizationType synchronizationType=cond::SYNCH_ANY)
~SiStripPayloadHandler() override
void setDescription(const std::string &description)
void analyze(const edm::Event &evt, const edm::EventSetup &evtSetup) override
Transaction & transaction()
def query(query_str, verbose=False)
SiStripPayloadHandler< SiStripPedestals > SiStripO2OPedestals
void setParameters(const edm::ParameterSet &connectionPset)
IOVProxy readIov(const std::string &tag, bool full=false)
SiStripPayloadHandler< SiStripBadStrip > SiStripO2OBadStrip
unsigned long long Time_t
SiStripPayloadHandler< SiStripApvGain > SiStripO2OApvGain
void getValue(SiStripFedCabling *&val)
Session createSession(const std::string &connectionString, bool writeCapable=false)
void setLastIovGain(std::shared_ptr< SiStripApvGain > gain)
std::string m_cfgMapDbFile
cond::persistency::ConnectionPool m_connectionPool
void insert(cond::Time_t since, const cond::Hash &payloadHash, bool checkType=false)
SiStripPayloadHandler(const edm::ParameterSet &iConfig)
cond::Hash storePayload(const T &payload, const boost::posix_time::ptime &creationTime=boost::posix_time::microsec_clock::universal_time())
std::vector< std::vector< double > > tmp
std::string m_localCondDbFile
std::string m_configMapDb
SiStripPayloadHandler< SiStripThreshold > SiStripO2OThreshold
SiStripPayloadHandler< SiStripLatency > SiStripO2OLatency
std::shared_ptr< coral::ISessionProxy > createCoralSession(const std::string &connectionString, bool writeCapable=false)
std::string makeConfigHash()
std::shared_ptr< T > fetchPayload(const cond::Hash &payloadHash)