4 #include <openssl/sha.h>
8 namespace persistency {
12 if( !SHA1_Init( &ctx ) ){
13 throwException(
"SHA1 initialization error.",
"IOVSchema::makeHash");
15 if( !SHA1_Update( &ctx, objectType.c_str(), objectType.size() ) ){
16 throwException(
"SHA1 processing error (1).",
"IOVSchema::makeHash");
18 if( !SHA1_Update( &ctx, data.
data(), data.
size() ) ){
19 throwException(
"SHA1 processing error (2).",
"IOVSchema::makeHash");
21 unsigned char hash[SHA_DIGEST_LENGTH];
22 if( !SHA1_Final(hash, &ctx) ){
26 char tmp[SHA_DIGEST_LENGTH*2+1];
28 for (
unsigned int i = 0;
i < 20;
i++) {
29 ::sprintf(&tmp[
i * 2],
"%02x", hash[i]);
39 bool TAG::Table::Table::exists(){
40 return existsTable( m_schema,
tname );
46 "TAG::Table::create");
50 createTable( m_schema, descr.
get() );
56 for (
auto row : q ) {}
58 return q.retrievedRows();
70 for (
auto row : q ) std::tie( timeType, objectType, synchronizationType, endOfValidity, description, lastValidatedTime ) = row;
72 return q.retrievedRows();
77 boost::posix_time::ptime& insertionTime,
78 boost::posix_time::ptime& modificationTime ){
81 for (
auto row : q ) std::tie( description, insertionTime, modificationTime ) = row;
82 return q.retrievedRows();
92 const boost::posix_time::ptime& insertionTime ){
94 dataToInsert( std::tie( name, timeType, objectType, synchronizationType, endOfValidity, description, lastValidatedTime, insertionTime, insertionTime ) );
95 insertInTable( m_schema,
tname, dataToInsert.
get() );
103 const boost::posix_time::ptime& updateTime ){
111 updateTable( m_schema,
tname, buffer );
116 const boost::posix_time::ptime& updateTime ){
120 updateTable( m_schema,
tname, buffer );
128 return existsTable( m_schema,
tname );
134 "IOV::Schema::create");
141 createTable( m_schema, descr.
get() );
150 groups.push_back(std::get<0>(row));
152 return q.retrievedRows();
162 groups.push_back(std::get<0>(row));
164 return q.retrievedRows();
168 std::vector<std::tuple<cond::Time_t,cond::Hash> >& iovs ){
175 size_t initialSize = iovs.
size();
178 if( iovs.size()-initialSize && std::get<0>(iovs.back()) == std::get<0>(row) )
continue;
179 iovs.push_back( row );
181 return iovs.size()-initialSize;
185 const boost::posix_time::ptime& snapshotTime,
186 std::vector<std::tuple<cond::Time_t,cond::Hash> >& iovs ){
194 size_t initialSize = iovs.
size();
195 for (
auto row : q ) {
197 if( iovs.size()-initialSize && std::get<0>(iovs.back()) == std::get<0>(row) )
continue;
198 iovs.push_back( row );
200 return iovs.size()-initialSize;
204 std::vector<std::tuple<cond::Time_t,cond::Hash> >& iovs ){
209 size_t initialSize = iovs.
size();
210 for (
auto row : q ) {
212 if( iovs.size()-initialSize && std::get<0>(iovs.back()) == std::get<0>(row) )
continue;
213 iovs.push_back( row );
215 return iovs.size()-initialSize;
219 const boost::posix_time::ptime& snapshotTime,
220 std::vector<std::tuple<cond::Time_t,cond::Hash> >& iovs){
226 size_t initialSize = iovs.
size();
227 for (
auto row : q ) {
229 if( iovs.size()-initialSize && std::get<0>(iovs.back()) == std::get<0>(row) )
continue;
230 iovs.push_back( row );
232 return iovs.size()-initialSize;
240 for (
auto row : q ) {
241 since = std::get<0>(row);
242 hash = std::get<1>(row);
254 for (
auto row : q ) {
255 since = std::get<0>(row);
256 hash = std::get<1>(row);
265 for (
auto row : q ) {
266 size = std::get<0>(row);
276 for (
auto row : q ) {
277 size = std::get<0>(row);
286 const boost::posix_time::ptime& insertTimeStamp ){
288 insertInTable( m_schema,
tname, dataToInsert.
get() );
292 const std::vector<std::tuple<cond::Time_t,cond::Hash,boost::posix_time::ptime> >& iovs ){
294 for(
auto row : iovs ) inserter.
insert( std::tuple_cat( std::tie(tag),row ) );
302 deleteFromTable( m_schema,
tname, buffer );
310 return existsTable( m_schema,
tname );
321 createTable( m_schema, descr.
get() );
325 const boost::posix_time::ptime& eventTime,
332 dataToInsert( std::tie( tag, eventTime, userName, hostName, command, action, userText ) );
333 insertInTable( m_schema,
tname, dataToInsert.
get() );
341 return existsTable( m_schema,
tname );
347 "PAYLOAD::Schema::create");
352 createTable( m_schema, descr.
get() );
358 for (
auto row : q ) {}
360 return q.retrievedRows();
366 for (
auto row : q ) {
367 objectType = std::get<0>(row);
370 return q.retrievedRows();
379 for (
auto row : q ) {
380 std::tie( payloadData, streamerInfoData, objectType ) = row;
382 return q.retrievedRows();
389 const boost::posix_time::ptime& insertionTime ){
393 RowBuffer< HASH, OBJECT_TYPE, DATA, STREAMER_INFO, VERSION, INSERTION_TIME > dataToInsert( std::tie( payloadHash, objectType, payloadData, sinfoData, version, insertionTime ) );
394 bool failOnDuplicate =
false;
395 return insertInTable( m_schema,
tname, dataToInsert.
get(), failOnDuplicate );
401 const boost::posix_time::ptime& insertionTime ){
404 if( !
select( payloadHash ) ){
405 insert( payloadHash, payloadObjectType, payloadData, streamerInfoData, insertionTime );
411 m_tagTable( schema ),
412 m_iovTable( schema ),
413 m_tagLogTable( schema ),
414 m_payloadTable( schema ){
425 bool created =
false;
bool getSnapshotLastIov(const std::string &tag, const boost::posix_time::ptime &snapshotTime, cond::Time_t &since, cond::Hash &hash)
bool getSnapshotSize(const std::string &tag, const boost::posix_time::ptime &snapshotTime, size_t &size)
static char const * tname
static std::string group()
ITagLogTable & tagLogTable()
bool getSize(const std::string &tag, size_t &size)
const coral::TableDescription & get()
void updateValidity(const std::string &name, cond::Time_t lastValidatedTime, const boost::posix_time::ptime &updateTime)
void insert(const P ¶ms)
Table(coral::ISchema &schema)
size_t selectLatest(const std::string &tag, std::vector< std::tuple< cond::Time_t, cond::Hash > > &iovs)
void update(const std::string &name, cond::SynchronizationType synchronizationType, cond::Time_t &endOfValidity, const std::string &description, cond::Time_t lastValidatedTime, const boost::posix_time::ptime &updateTime)
bool getLastIov(const std::string &tag, cond::Time_t &since, cond::Hash &hash)
PAYLOAD::Table m_payloadTable
void insertMany(const std::string &tag, const std::vector< std::tuple< cond::Time_t, cond::Hash, boost::posix_time::ptime > > &iovs)
size_t selectGroups(const std::string &tag, std::vector< cond::Time_t > &groups)
static char const * tname
void setForeignKey(const std::string &name)
bool select(const cond::Hash &payloadHash)
unsigned long long Time_t
void addCondition(const T &value, const std::string condition="=")
static char const * tname
const coral::AttributeList & get() const
void addOrderClause(bool ascending=true)
void erase(const std::string &tag)
void copy(const std::string &source)
IPayloadTable & payloadTable()
bool insert(Storage &iStorage, ItemType *iItem, const IdTag &iIdTag)
bool select(const std::string &name)
bool getType(const cond::Hash &payloadHash, std::string &objectType)
const void * data() const
TAG_LOG::Table m_tagLogTable
void setColumnData(const Params ¶ms)
void insert(const std::string &tag, const boost::posix_time::ptime &eventTime, const std::string &userName, const std::string &hostName, const std::string &command, const std::string &action, const std::string &userText)
Table(coral::ISchema &schema)
IOVSchema(coral::ISchema &schema)
cond::Hash insertIfNew(const std::string &objectType, const cond::Binary &payloadData, const cond::Binary &streamerInfoData, const boost::posix_time::ptime &insertionTime)
size_t selectSnapshot(const std::string &tag, const boost::posix_time::ptime &snapshotTime, std::vector< std::tuple< cond::Time_t, cond::Hash > > &iovs)
std::vector< std::vector< double > > tmp
char data[epos_bytes_allocation]
void groupBy(const std::string &expression)
cond::Hash makeHash(const std::string &objectType, const cond::Binary &data)
Table(coral::ISchema &schema)
size_t selectSnapshotByGroup(const std::string &tag, cond::Time_t lowerGroup, cond::Time_t upperGroup, const boost::posix_time::ptime &snapshotTime, std::vector< std::tuple< cond::Time_t, cond::Hash > > &iovs)
bool insert(const cond::Hash &payloadHash, const std::string &objectType, const cond::Binary &payloadData, const cond::Binary &streamerInfoData, const boost::posix_time::ptime &insertionTime)
volatile std::atomic< bool > shutdown_flag false
Table(coral::ISchema &schema)
static char const * tname
void insert(const std::string &name, cond::TimeType timeType, const std::string &objectType, cond::SynchronizationType synchronizationType, cond::Time_t endOfValidity, const std::string &description, cond::Time_t lastValidatedTime, const boost::posix_time::ptime &insertionTime)
void addWhereCondition(const P ¶m, const std::string condition="=")
bool getMetadata(const std::string &name, std::string &description, boost::posix_time::ptime &insertionTime, boost::posix_time::ptime &modificationTime)
const Time_t MAX_VAL(std::numeric_limits< Time_t >::max())
void insertOne(const std::string &tag, cond::Time_t since, cond::Hash payloadHash, const boost::posix_time::ptime &insertTime)
tuple size
Write out results.
void throwException(const std::string &message, const std::string &methodName)
size_t selectSnapshotGroups(const std::string &tag, const boost::posix_time::ptime &snapshotTime, std::vector< cond::Time_t > &groups)
size_t selectLatestByGroup(const std::string &tag, cond::Time_t lowerGroup, cond::Time_t upperGroup, std::vector< std::tuple< cond::Time_t, cond::Hash > > &iovs)
void addWhereCondition(const P ¶m, const std::string condition="=")