class AliShuttleConfig: public TObject {
public:
+ enum RunMode {kTest=0, kProd};
+ enum SystemCode { kDAQ = 0, kDCS, kHLT, kGlobal, kAmanda };
+
AliShuttleConfig(const char* host, Int_t port = LDAP_PORT,
const char* binddn = 0, const char* password = 0,
const char* basedn = "o=alice,dc=cern,dc=ch");
const char* GetConfigHost() const {return fConfigHost.Data();}
+ const char* GetAlienPath() const {return fAlienPath.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* 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* 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* GetShuttlelbTable() const {return fShuttlelbTable.Data();}
+ const char* GetRunTypelbTable() const {return fRunTypelbTable.Data();}
+
+ const char* GetFXSHost(Int_t sys) const {return fFXSHost[sys].Data();}
+ UInt_t GetFXSPort(Int_t sys) const {return fFXSPort[sys];}
+ const char* GetFXSUser(Int_t sys) const {return fFXSUser[sys].Data();}
+ const char* GetFXSPass(Int_t sys) const {return fFXSPass[sys].Data();}
+ const char* GetFXSBaseFolder(Int_t sys) const {return fFXSBaseFolder[sys].Data();}
+
+ const char* GetFXSdbHost(Int_t sys) const {return fFXSdbHost[sys].Data();}
+ UInt_t GetFXSdbPort(Int_t sys) const {return fFXSdbPort[sys];}
+ const char* GetFXSdbUser(Int_t sys) const {return fFXSdbUser[sys].Data();}
+ const char* GetFXSdbPass(Int_t sys) const {return fFXSdbPass[sys].Data();}
+ const char* GetFXSdbName(Int_t sys) const {return fFXSdbName[sys].Data();}
+ const char* GetFXSdbTable(Int_t sys) const {return fFXSdbTable[sys].Data();}
+
+ const TObjArray* GetAdmins(Int_t sys) const;
+
+ Bool_t SendMail() const { return fSendMail; }
+
Int_t GetMaxRetries() const { return fMaxRetries; }
Int_t GetPPTimeOut() const { return fPPTimeOut; }
-
- const TObjArray* GetDetectors() const;
+ Int_t GetDCSTimeOut() const { return fDCSTimeOut; }
+ Int_t GetDCSRetries() const { return fDCSRetries; }
+ UInt_t GetDCSQueryOffset() const { return fDCSQueryOffset; }
+ UInt_t GetDCSDelay() const { return fDCSDelay; }
+ Int_t GetPPMaxMem() const { return fPPMaxMem; }
+
+ const char* GetTerminateFilePath() const { return fTerminateFilePath; }
+
+ Bool_t KeepDCSMap() const { return fKeepDCSMap; }
+ Bool_t KeepTempFolder() const { return fKeepTempFolder; }
+
+
+ const char* GetMonitorHost() const {return fMonitorHost.Data();}
+ const char* GetMonitorTable() const {return fMonitorTable.Data();}
+
+ Int_t GetTriggerWait() const {return fTriggerWait;}
+ const char* GetShuttleFileSystem() const {return fShuttleFileSystem.Data();}
+ Int_t GetFreeDiskWarningThreshold() const {return fFreeDiskWarningThreshold;}
+ Int_t GetFreeDiskFatalThreshold() const {return fFreeDiskFatalThreshold;}
+
+ RunMode GetRunMode() const {return fRunMode;}
+
+ 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;
- const TObjArray* GetDCSDataPoints(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;
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;}
+ Int_t GetMultiSplit() const {return fMultiSplit;}
+
const TObjArray* GetDCSAliases() const {return fDCSAliases;}
const TObjArray* GetDCSDataPoints() const {return fDCSDataPoints;}
- const TObjArray* GetResponsibles() const {return fResponsibles;}
-
+ 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;}
- Bool_t SkipDCSQuery() const {return fSkipDCSQuery;}
- Bool_t StrictRunOrder() const {return fStrictRunOrder;}
-
- void ExpandAndAdd(TObjArray* target, const char* entry);
private:
- TString fDetector; // Detector name
+ 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* 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
+ 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(AliShuttleConfigHolder, 0);
+ ClassDef(AliShuttleDCSConfigHolder, 0);
};
+ class AliShuttleDetConfigHolder: public TObject {
+ public:
+ AliShuttleDetConfigHolder(const TLDAPEntry* entry);
+ ~AliShuttleDetConfigHolder();
- Bool_t fIsValid; //! flag for the validity of the configuration
-
- 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 MySQL 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
+ 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;}
- 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
+ private:
+ AliShuttleDetConfigHolder(const AliShuttleDetConfigHolder& other); // not implemented
+ AliShuttleDetConfigHolder& operator= (const AliShuttleDetConfigHolder& other); // not implemented
- Int_t fMaxRetries; // number of retries of a failed preprocessor
+ TString fDetector; // Detector name
+ 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
- Int_t fPPTimeOut; // timeout until a preprocessor is canceled
+ ClassDef(AliShuttleDetConfigHolder, 0);
+ };
- 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
+ AliShuttleConfig(const AliShuttleConfig& other);
+ AliShuttleConfig& operator= (const AliShuttleConfig& other);
+ UInt_t SetGlobalConfig(TList* globalList);
+ UInt_t SetSysConfig(TList* sysList);
+ UInt_t SetPasswords();
+ UInt_t SetDetConfig(TList* detList, TList* dcsList);
+ UInt_t SetHostConfig(TList* hostList);
+
+ TString fConfigHost; // Host of the Shuttle configuration LDAP server
+
+ TString fAlienPath; // Alien Path for CDB/Reference objs in the Alien catalogue
+
+ 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 fPasswdFilePath; // Path for the local file where the passwords are stored
+
+ 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 fFXSBaseFolder[3]; // base folder of the [DAQ, DCS, HLT] File eXchange Server
+
+ 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
+
+ TString fTerminateFilePath; // File for inter-process communcation to terminate the Shuttle
+
+ Int_t fMaxRetries; // number of retries of a failed preprocessor
+
+ Int_t fPPTimeOut; // timeout until a preprocessor is killed
+ Int_t fDCSTimeOut; // timeout until the query to DCS is terminated
+ Int_t fDCSRetries; // number of retries until the query to DCS connection is terminated
+ UInt_t fDCSQueryOffset; // offset for the DCS DPs query, to be subracted from the StartTime and
+ // added to the EndTime
+ UInt_t fDCSDelay; // delay to make the query to DCS
+ Int_t fPPMaxMem; // maximum allowed memory until a preprocessor is killed
+
+ TString fMonitorHost; // host of the MonaLisa monitoring server
+ TString fMonitorTable; // Monalisa's SHUTTLE table name
+
+ Int_t fTriggerWait; // time to wait for DIM trigger before starting new collection
+ TString fShuttleFileSystem; // path of the Shuttle file system
+ Int_t fFreeDiskWarningThreshold; // threshold for free space in the Shuttle file system to send a mail to the responsibles
+ Int_t fFreeDiskFatalThreshold; // threshold for free space in the Shuttle file system to send a mail to the responsibles and terminate the Shuttle
+ RunMode fRunMode; // Working mode (0=test; 1=prod)
+
+ TMap fDetectorMap; // Map of the detector-by-detector configuration
+ TObjArray fDetectorList; // List of detectors with valid configuration
+
+ TObjArray *fAdmin[5]; // Array of system administrators' email addresses (DAQ, DCS, HLT, Global, Amanda)
+
+ TString fShuttleInstanceHost; // Instance of the SHUTTLE
+ TObjArray fProcessedDetectors; // list of the detector to be processed by this machine
+
+ Bool_t fKeepDCSMap; // Flag to keep DCS map also in case of success
+ Bool_t fKeepTempFolder; // Flag to keep temp folder also in case of success
+
+ Bool_t fSendMail; // Send mail flag
+
+ Bool_t fProcessAll; // flag indicating that all detectors will be processed
+ Bool_t fIsValid; // flag for the validity of the configuration
ClassDef(AliShuttleConfig, 0);
};