X-Git-Url: http://git.uio.no/git/?p=u%2Fmrichter%2FAliRoot.git;a=blobdiff_plain;f=SHUTTLE%2FAliShuttleConfig.h;h=40ba456cfbe9e26d21949cae19f3e90d9f1306f9;hp=4db461edc43ff6d665b53779c9598cfc9aa4ba4e;hb=de605761089a0e3ff4892cf79aedbd180df39839;hpb=2c15234ce57fa8b951f1714556a191165bde25c7 diff --git a/SHUTTLE/AliShuttleConfig.h b/SHUTTLE/AliShuttleConfig.h index 4db461edc43..40ba456cfbe 100644 --- a/SHUTTLE/AliShuttleConfig.h +++ b/SHUTTLE/AliShuttleConfig.h @@ -20,6 +20,9 @@ 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"); @@ -27,33 +30,78 @@ public: Bool_t IsValid() const {return fIsValid;}; + 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();} - 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();} - 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; void SetProcessAll(Bool_t flag=kTRUE) {fProcessAll=flag;} @@ -65,64 +113,150 @@ public: 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* 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;} 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 - 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 fDAQlbHost; //! Host 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 - 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 - 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); };