Bool_t IsValid() const {return fIsValid;};
+ const char* GetConfigHost() const {return fConfigHost.Data();}
+
const char* GetDAQlbHost() const {return fDAQlbHost.Data();}
+ UInt_t GetDAQlbPort() const {return fDAQlbPort;}
const char* GetDAQlbUser() const {return fDAQlbUser.Data();}
const char* GetDAQlbPass() const {return fDAQlbPass.Data();}
+ const char* GetDAQlbDB() const {return fDAQlbDB.Data();}
+ const char* GetDAQlbTable() const {return fDAQlbTable.Data();}
+ const char* GetShuttlelbTable() const {return fShuttlelbTable.Data();}
+ const char* GetRunTypelbTable() const {return fRunTypelbTable.Data();}
+
+ const char* GetFXSHost(Int_t system) const {return fFXSHost[system].Data();}
+ UInt_t GetFXSPort(Int_t system) const {return fFXSPort[system];}
+ const char* GetFXSUser(Int_t system) const {return fFXSUser[system].Data();}
+ const char* GetFXSPass(Int_t system) const {return fFXSPass[system].Data();}
- const char* GetFESHost(Int_t system) const {return fFESHost[system].Data();}
- const char* GetFESUser(Int_t system) const {return fFESUser[system].Data();}
- const char* GetFESPass(Int_t system) const {return fFESPass[system].Data();}
+ const char* GetFXSdbHost(Int_t system) const {return fFXSdbHost[system].Data();}
+ UInt_t GetFXSdbPort(Int_t system) const {return fFXSdbPort[system];}
+ const char* GetFXSdbUser(Int_t system) const {return fFXSdbUser[system].Data();}
+ const char* GetFXSdbPass(Int_t system) const {return fFXSdbPass[system].Data();}
+ const char* GetFXSdbName(Int_t system) const {return fFXSdbName[system].Data();}
+ const char* GetFXSdbTable(Int_t system) const {return fFXSdbTable[system].Data();}
- const char* GetFESlbHost(Int_t system) const {return fFESlbHost[system].Data();}
- const char* GetFESlbUser(Int_t system) const {return fFESlbUser[system].Data();}
- const char* GetFESlbPass(Int_t system) const {return fFESlbPass[system].Data();}
+ Int_t GetMaxRetries() const { return fMaxRetries; }
- Int_t GetMaxPPRetries() const { return fMaxPPRetries; }
- Int_t GetMaxRetries() const { return fMaxRetries; }
+ Int_t GetPPTimeOut() const { return fPPTimeOut; }
+ Int_t GetPPMaxMem() const { return fPPMaxMem; }
const TObjArray* GetDetectors() const;
Bool_t HasDetector(const char* detector) const;
- const char* GetDCSHost(const char* detector) const;
- Int_t GetDCSPort(const char* detector) const;
- const TObjArray* GetDCSAliases(const char* detector) const;
+
+ Int_t GetNServers(const char* detector) const;
+
+ const char* GetDCSHost(const char* detector, Int_t iServ) const;
+ Int_t GetDCSPort(const char* detector, Int_t iServ) const;
+
+ Int_t GetMultiSplit(const char* detector, Int_t iServ) const;
+
+ const TObjArray* GetDCSAliases(const char* detector, Int_t iServ) const;
+ const TObjArray* GetDCSDataPoints(const char* detector, Int_t iServ) const;
+ const TObjArray* GetCompactDCSAliases(const char* detector, Int_t iServ) const;
+ const TObjArray* GetCompactDCSDataPoints(const char* detector, Int_t iServ) const;
+
+ const TObjArray* GetResponsibles(const char* detector) const;
+ Bool_t StrictRunOrder(const char* detector) const;
void SetProcessAll(Bool_t flag=kTRUE) {fProcessAll=flag;}
Bool_t ProcessAll() const {return fProcessAll;}
private:
- class AliShuttleConfigHolder: public TObject {
+ class AliShuttleDCSConfigHolder: public TObject {
public:
- AliShuttleConfigHolder(const TLDAPEntry* entry);
- ~AliShuttleConfigHolder();
-
- const char* GetDetector() const {return fDetector.Data();}
- const char* GetDCSHost() const {return fDCSHost.Data();}
+ AliShuttleDCSConfigHolder(const TLDAPEntry* entry);
+ ~AliShuttleDCSConfigHolder();
+
+ const char* GetDCSHost() const {return fDCSHost;}
Int_t GetDCSPort() const {return fDCSPort;}
- const TObjArray* GetDCSAliases() const {return &fDCSAliases;}
+ Int_t GetMultiSplit() const {return fMultiSplit;}
+
+ const TObjArray* GetDCSAliases() const {return fDCSAliases;}
+ const TObjArray* GetDCSDataPoints() const {return fDCSDataPoints;}
+ const TObjArray* GetCompactDCSAliases() const {return fDCSAliasesComp;}
+ const TObjArray* GetCompactDCSDataPoints() const {return fDCSDataPointsComp;}
+
+ void ExpandAndAdd(TObjArray* target, const char* entry);
+ Bool_t IsValid() const {return fIsValid;}
+
+ private:
+ AliShuttleDCSConfigHolder(const AliShuttleDCSConfigHolder& other); // not implemented
+ AliShuttleDCSConfigHolder& operator= (const AliShuttleDCSConfigHolder& other); // not implemented
+
+ TString fDCSHost; // Host name of the DCS server
+ Int_t fDCSPort; // port of the DCS server
+ Int_t fMultiSplit; // N. of DPs to be queried in each query chunk
+ TObjArray* fDCSAliases; // List of DCS aliases to be retrieved
+ TObjArray* fDCSDataPoints; // List of DCS data points to be retrieved
+ TObjArray* fDCSAliasesComp; // Compact list of DCS aliases to be printed
+ TObjArray* fDCSDataPointsComp; // Compact list of DCS data points to be printed
+ Bool_t fIsValid; // flag for the validity of the configuration
+
+ ClassDef(AliShuttleDCSConfigHolder, 0);
+ };
+ class AliShuttleDetConfigHolder: public TObject {
+ public:
+ AliShuttleDetConfigHolder(const TLDAPEntry* entry);
+ ~AliShuttleDetConfigHolder();
+
+ const char* GetDetector() const {return fDetector.Data();}
+ const TObjArray* GetDCSConfig() const {return fDCSConfig;}
+ void AddDCSConfig(AliShuttleDCSConfigHolder* holder);
+
+ Int_t GetNServers() const {return fDCSConfig ? fDCSConfig->GetEntries() : 0;}
+
+ const char* GetDCSHost(Int_t iServ) const;
+ Int_t GetDCSPort(Int_t iServ) const;
+ Int_t GetMultiSplit(Int_t iServ) const;
+
+ const TObjArray* GetDCSAliases(Int_t iServ) const;
+ const TObjArray* GetDCSDataPoints(Int_t iServ) const;
+ const TObjArray* GetCompactDCSAliases(Int_t iServ) const;
+ const TObjArray* GetCompactDCSDataPoints(Int_t iServ) const;
+
+ const TObjArray* GetResponsibles() const {return fResponsibles;}
Bool_t IsValid() const {return fIsValid;}
Bool_t SkipDCSQuery() const {return fSkipDCSQuery;}
+ Bool_t StrictRunOrder() const {return fStrictRunOrder;}
private:
+ AliShuttleDetConfigHolder(const AliShuttleDetConfigHolder& other); // not implemented
+ AliShuttleDetConfigHolder& operator= (const AliShuttleDetConfigHolder& other); // not implemented
+
TString fDetector; // Detector name
- TString fDCSHost; // Host name of the DCS server
- Int_t fDCSPort; // port of the DCS server
- TObjArray fDCSAliases; // List of DCS aliases to be retrieved
+ TObjArray* fDCSConfig; // Array of DCS configuration objects (AliShuttleDCSConfigHolder)
+ TObjArray* fResponsibles; // List of email addresses of the detector's responsible(s)
Bool_t fIsValid; // flag for the validity of the configuration
Bool_t fSkipDCSQuery; // flag - if TRUE (-> DCS config empty) skip DCS archive data query
+ Bool_t fStrictRunOrder; // flag - if TRUE connect data in a strict run ordering
-
- ClassDef(AliShuttleConfigHolder, 0);
+ ClassDef(AliShuttleDetConfigHolder, 0);
};
- Bool_t fIsValid; //! flag for the validity of the configuration
+ UInt_t SetGlobalConfig(TList* globalList);
+ UInt_t SetSysConfig(TList* sysList);
+ UInt_t SetDetConfig(TList* detList, TList* dcsList);
+ UInt_t SetHostConfig(TList* hostList);
+
+ TString fConfigHost; //! Host of the Shuttle configuration LDAP server
TString fDAQlbHost; //! Host of the DAQ logbook MySQL Server
+ UInt_t fDAQlbPort; //! port of the DAQ logbook MySQL Server
TString fDAQlbUser; //! username of the DAQ logbook MySQL Server
TString fDAQlbPass; //! password of the DAQ logbook MySQL Server
+ TString fDAQlbDB; //! DB name of the DAQ logbook MySQL Server
+ TString fDAQlbTable; //! Table name of the DAQ logbook
+ TString fShuttlelbTable; //! Table name of the Shuttle logbook
+ TString fRunTypelbTable; //! Table name of the Run typr logbook
- TString fFESHost[3]; //! Host of the [DAQ, DCS, HLT] File Exchange Server
- TString fFESUser[3]; //! username of the [DAQ, DCS, HLT] File Exchange Server
- TString fFESPass[3]; //! password of the [DAQ, DCS, HLT] File Exchange Server
+ TString fFXSHost[3]; //! Host of the [DAQ, DCS, HLT] File eXchange Server
+ UInt_t fFXSPort[3]; //! Port of the [DAQ, DCS, HLT] File eXchange Server
+ TString fFXSUser[3]; //! username of the [DAQ, DCS, HLT] File eXchange Server
+ TString fFXSPass[3]; //! password of the [DAQ, DCS, HLT] File eXchange Server
- TString fFESlbHost[3]; //! Host of the [DAQ, DCS, HLT] FES logbook
- TString fFESlbUser[3]; //! username of the [DAQ, DCS, HLT] FES logbook
- TString fFESlbPass[3]; //! password of the [DAQ, DCS, HLT] FES logbook
+ TString fFXSdbHost[3]; //! Host of the [DAQ, DCS, HLT] FXS database
+ UInt_t fFXSdbPort[3]; //! Port of the [DAQ, DCS, HLT] FXS database
+ TString fFXSdbUser[3]; //! username of the [DAQ, DCS, HLT] FXS database
+ TString fFXSdbPass[3]; //! password of the [DAQ, DCS, HLT] FXS database
+ TString fFXSdbName[3]; //! name of the [DAQ, DCS, HLT] FXS database
+ TString fFXSdbTable[3]; //! Table name of the [DAQ, DCS, HLT] FXS database
- Int_t fMaxPPRetries; // number of retries of a crashed preprocessor
- Int_t fMaxRetries; // number of retries for all other failures
+ Int_t fMaxRetries; // number of retries of a failed preprocessor
+
+ Int_t fPPTimeOut; // timeout until a preprocessor is killed
+ Int_t fPPMaxMem; // maximum allowed memory until a preprocessor is killed
TMap fDetectorMap; //! Map of the detector-by-detector configuration
TObjArray fDetectorList; //! List of detectors with valid configuration
TString fShuttleInstanceHost; //! Instance of the SHUTTLE
TObjArray fProcessedDetectors; //! list of the detector to be processed by this machine
Bool_t fProcessAll; //! flag indicating that all detectors will be processed
+ Bool_t fIsValid; //! flag for the validity of the configuration
ClassDef(AliShuttleConfig, 0);
};