CMS 3D CMS Logo

L1SubsystemKeysOnlineProd.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: L1SubsystemKeysOnlineProd
4 // Class: L1SubsystemKeysOnlineProd
5 //
13 //
14 // Original Author: Werner Man-Li Sun
15 // Created: Thu Aug 21 20:00:59 CEST 2008
16 // $Id: L1SubsystemKeysOnlineProd.cc,v 1.5 2010/02/01 22:00:03 wsun Exp $
17 //
18 //
19 
20 
21 // system include files
22 
23 // user include files
25 
27 
30 
33 
35 
36 //
37 // class declaration
38 //
39 
40 //
41 // constants, enums and typedefs
42 //
43 
44 //
45 // static data member definitions
46 //
47 
48 //
49 // constructors and destructor
50 //
52  : m_tscKey( iConfig.getParameter< std::string >( "tscKey" ) ),
53  m_omdsReader(
54  iConfig.getParameter< std::string >( "onlineDB" ),
55  iConfig.getParameter< std::string >( "onlineAuthentication" ) ),
56  m_forceGeneration( iConfig.getParameter< bool >( "forceGeneration" ) )
57 {
58  //the following line is needed to tell the framework what
59  // data is being produced
60  setWhatProduced(this, "SubsystemKeysOnly");
61 
62  //now do what ever other initialization is needed
63 }
64 
65 
67 {
68 
69  // do anything here that needs to be done at desctruction time
70  // (e.g. close files, deallocate resources etc.)
71 
72 }
73 
74 
75 //
76 // member functions
77 //
78 
79 // ------------ method called to produce the data ------------
82 {
83  std::unique_ptr<L1TriggerKey> pL1TriggerKey ;
84 
85  // Get L1TriggerKeyList
86  L1TriggerKeyList keyList ;
87  l1t::DataWriter dataWriter ;
88  if( !dataWriter.fillLastTriggerKeyList( keyList ) )
89  {
90  edm::LogError( "L1-O2O" )
91  << "Problem getting last L1TriggerKeyList" ;
92  }
93 
94  // If L1TriggerKeyList does not contain TSC key, token is empty
95  if( keyList.token( m_tscKey ).empty() ||
97  {
98  // Instantiate new L1TriggerKey
99  pL1TriggerKey = std::make_unique< L1TriggerKey >() ;
100  pL1TriggerKey->setTSCKey( m_tscKey ) ;
101 
102  edm::LogVerbatim( "L1-O2O" ) << "TSC KEY " << m_tscKey ;
103 
104  // Get subsystem keys from OMDS
105 
106  // SELECT CSCTF_KEY, DTTF_KEY, RPC_KEY, GMT_KEY, RCT_KEY, GCT_KEY, GT_KEY FROM TRIGGERSUP_CONF WHERE TRIGGERSUP_CONF.TS_KEY = m_tscKey
107  std::vector< std::string > queryStrings ;
108  queryStrings.push_back( "CSCTF_KEY" ) ;
109  queryStrings.push_back( "DTTF_KEY" ) ;
110  queryStrings.push_back( "RPC_KEY" ) ;
111  queryStrings.push_back( "GMT_KEY" ) ;
112  queryStrings.push_back( "RCT_KEY" ) ;
113  queryStrings.push_back( "GCT_KEY" ) ;
114  queryStrings.push_back( "GT_KEY" ) ;
115  // queryStrings.push_back( "TSP0_KEY" ) ;
116 
117  l1t::OMDSReader::QueryResults subkeyResults =
118  m_omdsReader.basicQuery( queryStrings,
119  "CMS_TRG_L1_CONF",
120  "TRIGGERSUP_CONF",
121  "TRIGGERSUP_CONF.TS_KEY",
123 
124  if( subkeyResults.queryFailed() ||
125  subkeyResults.numberRows() != 1 ) // check query successful
126  {
127  edm::LogError( "L1-O2O" ) << "Problem with subsystem keys." ;
128  return pL1TriggerKey ;
129  }
130 
131  std::string csctfKey, dttfKey, rpcKey, gmtKey, rctKey, gctKey, gtKey ;
132 
133  subkeyResults.fillVariable( "CSCTF_KEY", csctfKey ) ;
134  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kCSCTF, csctfKey ) ;
135  edm::LogVerbatim( "L1-O2O" ) << "CSCTF_KEY " << csctfKey ;
136 
137  subkeyResults.fillVariable( "DTTF_KEY", dttfKey ) ;
138  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kDTTF, dttfKey ) ;
139  edm::LogVerbatim( "L1-O2O" ) << "DTTF_KEY " << dttfKey ;
140 
141  subkeyResults.fillVariable( "RPC_KEY", rpcKey ) ;
142  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kRPC, rpcKey ) ;
143  edm::LogVerbatim( "L1-O2O" ) << "RPC_KEY " << rpcKey ;
144 
145  subkeyResults.fillVariable( "GMT_KEY", gmtKey ) ;
146  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kGMT, gmtKey ) ;
147  edm::LogVerbatim( "L1-O2O" ) << "GMT_KEY " << gmtKey ;
148 
149  subkeyResults.fillVariable( "RCT_KEY", rctKey ) ;
150  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kRCT, rctKey ) ;
151  edm::LogVerbatim( "L1-O2O" ) << "RCT_KEY " << rctKey ;
152 
153  subkeyResults.fillVariable( "GCT_KEY", gctKey ) ;
154  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kGCT, gctKey ) ;
155  edm::LogVerbatim( "L1-O2O" ) << "GCT_KEY " << gctKey ;
156 
157  subkeyResults.fillVariable( "GT_KEY", gtKey ) ;
158  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kGT, gtKey ) ;
159  edm::LogVerbatim( "L1-O2O" ) << "GT_KEY " << gtKey ;
160 
161  // std::string tsp0Key = row[ "TSP0_KEY" ].data< std::string >() ;
162  std::string tsp0Key ;
163  pL1TriggerKey->setSubsystemKey( L1TriggerKey::kTSP0, tsp0Key ) ;
164  edm::LogVerbatim( "L1-O2O" ) << "TSP0_KEY " << tsp0Key ;
165  }
166  else
167  {
169  "L1TriggerKey for TSC key " + m_tscKey + " already in CondDB." ) ;
170  }
171 
172  return pL1TriggerKey ;
173 }
174 
175 //define this as a plug-in
176 //DEFINE_FWK_EVENTSETUP_MODULE(L1SubsystemKeysOnlineProd);
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:124
bool fillVariable(const std::string &columnName, T &outputVariable) const
Definition: OMDSReader.h:311
const QueryResults singleAttribute(const T &data) const
Definition: OMDSReader.h:295
std::unique_ptr< L1TriggerKey > ReturnType
ReturnType produce(const L1TriggerKeyRcd &)
const QueryResults basicQuery(const std::vector< std::string > &columnNames, const std::string &schemaName, const std::string &tableName, const std::string &conditionLHS="", const QueryResults conditionRHS=QueryResults(), const std::string &conditionRHSName="")
Definition: OMDSReader.cc:86
bool fillLastTriggerKeyList(L1TriggerKeyList &output)
Definition: DataWriter.cc:198
std::string token(const std::string &tscKey) const
L1SubsystemKeysOnlineProd(const edm::ParameterSet &)