Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
/*
 *  See headers for a description
 *
 *  \author D. Pagano - Dip. Fis. Nucl. e Teo. & INFN Pavia
 */

#include "CondTools/RPC/interface/RPCVmonSH.h"
#include "FWCore/ServiceRegistry/interface/Service.h"
#include "CondCore/DBOutputService/interface/PoolDBOutputService.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include <iostream>

popcon::RpcDataV::RpcDataV(const edm::ParameterSet& pset)
    : m_name(pset.getUntrackedParameter<std::string>("name", "RpcData")),
      host(pset.getUntrackedParameter<std::string>("host", "source db host")),
      user(pset.getUntrackedParameter<std::string>("user", "source username")),
      passw(pset.getUntrackedParameter<std::string>("passw", "source password")),
      m_since(pset.getUntrackedParameter<unsigned long long>("since", 5)),
      m_till(pset.getUntrackedParameter<unsigned long long>("till", 0)) {}

popcon::RpcDataV::~RpcDataV() {}

void popcon::RpcDataV::getNewObjects() {
  std::cout << "------- " << m_name << " - > getNewObjects\n"
            << "got offlineInfo " << tagInfo().name << ", size " << tagInfo().size << ", last object valid since "
            << tagInfo().lastInterval.since << " token " << tagInfo().lastInterval.payloadId << std::endl;

  std::cout << " ------ last entry info regarding the payload (if existing): " << logDBEntry().usertext
            << "last record with the correct tag has been written in the db: " << logDBEntry().destinationDB
            << std::endl;

  //  snc = tagInfo().lastInterval.first;

  std::cout << std::endl << "=============================================" << std::endl;
  std::cout << std::endl << "===================  VMON  ==================" << std::endl;
  std::cout << std::endl << "=============================================" << std::endl << std::endl;
  snc = m_since;
  std::cout << ">> Range mode [" << snc << ", " << m_till << "]" << std::endl;
  std::cout << std::endl << "=============================================" << std::endl << std::endl;

  RPCFw caen(host, user, passw);
  std::vector<RPCObVmon::V_Item> Vcheck;

  Vcheck = caen.createVMON(snc, m_till);
  Vdata = new RPCObVmon();
  RPCObVmon::V_Item Vfill;
  std::vector<RPCObVmon::V_Item>::iterator Vit;
  for (Vit = Vcheck.begin(); Vit != Vcheck.end(); Vit++) {
    Vfill = *(Vit);
    Vdata->ObVmon_rpc.push_back(Vfill);
  }
  std::cout << " >> Final object size: " << Vdata->ObVmon_rpc.size() << std::endl;

  if (!Vdata->ObVmon_rpc.empty()) {
    niov = snc;
  } else {
    niov = snc;
    std::cout << "NO DATA TO BE STORED" << std::endl;
  }

  ::timeval tv;
  tv.tv_sec = niov;
  tv.tv_usec = 0;
  edm::Timestamp tmstamp((unsigned long long)tv.tv_sec * 1000000 + (unsigned long long)tv.tv_usec);
  std::cout << "UNIX time = " << tmstamp.value() << std::endl;

  edm::TimeValue_t daqtime = 0LL;
  daqtime = tv.tv_sec;
  daqtime = (daqtime << 32) + tv.tv_usec;
  edm::Timestamp daqstamp(daqtime);
  edm::TimeValue_t dtime = daqstamp.value();
  std::cout << "DAQ time = " << dtime << std::endl;

  niov = dtime;

  std::cout << "===> New IOV: since is = " << niov << std::endl;
  m_to_transfer.push_back(std::make_pair((RPCObVmon*)Vdata, niov));
}