1 #ifndef ALI_SHUTTLE_CONFIG_H
2 #define ALI_SHUTTLE_CONFIG_H
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
10 // This class keeps the AliShuttle configuration.
11 // It reads the configuration for LDAP server.
12 // For more info see AliShuttleConfig.cxx
17 #include <TObjArray.h>
19 #include <TLDAPServer.h>
21 class AliShuttleConfig: public TObject {
23 AliShuttleConfig(const char* host, Int_t port = LDAP_PORT,
24 const char* binddn = 0, const char* password = 0,
25 const char* basedn = "o=alice,dc=cern,dc=ch");
26 virtual ~AliShuttleConfig();
28 Bool_t IsValid() const {return fIsValid;};
30 const char* GetConfigHost() const {return fConfigHost.Data();}
32 const char* GetDAQlbHost() const {return fDAQlbHost.Data();}
33 UInt_t GetDAQlbPort() const {return fDAQlbPort;}
34 const char* GetDAQlbUser() const {return fDAQlbUser.Data();}
35 const char* GetDAQlbPass() const {return fDAQlbPass.Data();}
36 const char* GetDAQlbDB() const {return fDAQlbDB.Data();}
37 const char* GetDAQlbTable() const {return fDAQlbTable.Data();}
38 const char* GetShuttlelbTable() const {return fShuttlelbTable.Data();}
39 const char* GetRunTypelbTable() const {return fRunTypelbTable.Data();}
41 const char* GetFXSHost(Int_t system) const {return fFXSHost[system].Data();}
42 UInt_t GetFXSPort(Int_t system) const {return fFXSPort[system];}
43 const char* GetFXSUser(Int_t system) const {return fFXSUser[system].Data();}
44 const char* GetFXSPass(Int_t system) const {return fFXSPass[system].Data();}
46 const char* GetFXSdbHost(Int_t system) const {return fFXSdbHost[system].Data();}
47 UInt_t GetFXSdbPort(Int_t system) const {return fFXSdbPort[system];}
48 const char* GetFXSdbUser(Int_t system) const {return fFXSdbUser[system].Data();}
49 const char* GetFXSdbPass(Int_t system) const {return fFXSdbPass[system].Data();}
50 const char* GetFXSdbName(Int_t system) const {return fFXSdbName[system].Data();}
51 const char* GetFXSdbTable(Int_t system) const {return fFXSdbTable[system].Data();}
53 Int_t GetMaxRetries() const { return fMaxRetries; }
55 Int_t GetPPTimeOut() const { return fPPTimeOut; }
56 Int_t GetPPMaxMem() const { return fPPMaxMem; }
58 const TObjArray* GetDetectors() const;
60 Bool_t HasDetector(const char* detector) const;
62 Int_t GetNServers(const char* detector) const;
64 const char* GetDCSHost(const char* detector, Int_t iServ) const;
65 Int_t GetDCSPort(const char* detector, Int_t iServ) const;
67 Int_t GetMultiSplit(const char* detector, Int_t iServ) const;
69 const TObjArray* GetDCSAliases(const char* detector, Int_t iServ) const;
70 const TObjArray* GetDCSDataPoints(const char* detector, Int_t iServ) const;
71 const TObjArray* GetCompactDCSAliases(const char* detector, Int_t iServ) const;
72 const TObjArray* GetCompactDCSDataPoints(const char* detector, Int_t iServ) const;
74 const TObjArray* GetResponsibles(const char* detector) const;
75 Bool_t StrictRunOrder(const char* detector) const;
77 void SetProcessAll(Bool_t flag=kTRUE) {fProcessAll=flag;}
78 Bool_t ProcessAll() const {return fProcessAll;}
80 Bool_t HostProcessDetector(const char* detector) const;
82 virtual void Print(Option_t* option = NULL) const;
86 class AliShuttleDCSConfigHolder: public TObject {
88 AliShuttleDCSConfigHolder(const TLDAPEntry* entry);
89 ~AliShuttleDCSConfigHolder();
91 const char* GetDCSHost() const {return fDCSHost;}
92 Int_t GetDCSPort() const {return fDCSPort;}
93 Int_t GetMultiSplit() const {return fMultiSplit;}
95 const TObjArray* GetDCSAliases() const {return fDCSAliases;}
96 const TObjArray* GetDCSDataPoints() const {return fDCSDataPoints;}
97 const TObjArray* GetCompactDCSAliases() const {return fDCSAliasesComp;}
98 const TObjArray* GetCompactDCSDataPoints() const {return fDCSDataPointsComp;}
100 void ExpandAndAdd(TObjArray* target, const char* entry);
101 Bool_t IsValid() const {return fIsValid;}
104 AliShuttleDCSConfigHolder(const AliShuttleDCSConfigHolder& other); // not implemented
105 AliShuttleDCSConfigHolder& operator= (const AliShuttleDCSConfigHolder& other); // not implemented
107 TString fDCSHost; // Host name of the DCS server
108 Int_t fDCSPort; // port of the DCS server
109 Int_t fMultiSplit; // N. of DPs to be queried in each query chunk
110 TObjArray* fDCSAliases; // List of DCS aliases to be retrieved
111 TObjArray* fDCSDataPoints; // List of DCS data points to be retrieved
112 TObjArray* fDCSAliasesComp; // Compact list of DCS aliases to be printed
113 TObjArray* fDCSDataPointsComp; // Compact list of DCS data points to be printed
114 Bool_t fIsValid; // flag for the validity of the configuration
116 ClassDef(AliShuttleDCSConfigHolder, 0);
119 class AliShuttleDetConfigHolder: public TObject {
121 AliShuttleDetConfigHolder(const TLDAPEntry* entry);
122 ~AliShuttleDetConfigHolder();
124 const char* GetDetector() const {return fDetector.Data();}
125 const TObjArray* GetDCSConfig() const {return fDCSConfig;}
126 void AddDCSConfig(AliShuttleDCSConfigHolder* holder);
128 Int_t GetNServers() const {return fDCSConfig ? fDCSConfig->GetEntries() : 0;}
130 const char* GetDCSHost(Int_t iServ) const;
131 Int_t GetDCSPort(Int_t iServ) const;
132 Int_t GetMultiSplit(Int_t iServ) const;
134 const TObjArray* GetDCSAliases(Int_t iServ) const;
135 const TObjArray* GetDCSDataPoints(Int_t iServ) const;
136 const TObjArray* GetCompactDCSAliases(Int_t iServ) const;
137 const TObjArray* GetCompactDCSDataPoints(Int_t iServ) const;
139 const TObjArray* GetResponsibles() const {return fResponsibles;}
140 Bool_t IsValid() const {return fIsValid;}
141 Bool_t SkipDCSQuery() const {return fSkipDCSQuery;}
142 Bool_t StrictRunOrder() const {return fStrictRunOrder;}
145 AliShuttleDetConfigHolder(const AliShuttleDetConfigHolder& other); // not implemented
146 AliShuttleDetConfigHolder& operator= (const AliShuttleDetConfigHolder& other); // not implemented
148 TString fDetector; // Detector name
149 TObjArray* fDCSConfig; // Array of DCS configuration objects (AliShuttleDCSConfigHolder)
150 TObjArray* fResponsibles; // List of email addresses of the detector's responsible(s)
151 Bool_t fIsValid; // flag for the validity of the configuration
152 Bool_t fSkipDCSQuery; // flag - if TRUE (-> DCS config empty) skip DCS archive data query
153 Bool_t fStrictRunOrder; // flag - if TRUE connect data in a strict run ordering
155 ClassDef(AliShuttleDetConfigHolder, 0);
159 UInt_t SetGlobalConfig(TList* globalList);
160 UInt_t SetSysConfig(TList* sysList);
161 UInt_t SetDetConfig(TList* detList, TList* dcsList);
162 UInt_t SetHostConfig(TList* hostList);
164 TString fConfigHost; //! Host of the Shuttle configuration LDAP server
166 TString fDAQlbHost; //! Host of the DAQ logbook MySQL Server
167 UInt_t fDAQlbPort; //! port of the DAQ logbook MySQL Server
168 TString fDAQlbUser; //! username of the DAQ logbook MySQL Server
169 TString fDAQlbPass; //! password of the DAQ logbook MySQL Server
170 TString fDAQlbDB; //! DB name of the DAQ logbook MySQL Server
171 TString fDAQlbTable; //! Table name of the DAQ logbook
172 TString fShuttlelbTable; //! Table name of the Shuttle logbook
173 TString fRunTypelbTable; //! Table name of the Run typr logbook
175 TString fFXSHost[3]; //! Host of the [DAQ, DCS, HLT] File eXchange Server
176 UInt_t fFXSPort[3]; //! Port of the [DAQ, DCS, HLT] File eXchange Server
177 TString fFXSUser[3]; //! username of the [DAQ, DCS, HLT] File eXchange Server
178 TString fFXSPass[3]; //! password of the [DAQ, DCS, HLT] File eXchange Server
180 TString fFXSdbHost[3]; //! Host of the [DAQ, DCS, HLT] FXS database
181 UInt_t fFXSdbPort[3]; //! Port of the [DAQ, DCS, HLT] FXS database
182 TString fFXSdbUser[3]; //! username of the [DAQ, DCS, HLT] FXS database
183 TString fFXSdbPass[3]; //! password of the [DAQ, DCS, HLT] FXS database
184 TString fFXSdbName[3]; //! name of the [DAQ, DCS, HLT] FXS database
185 TString fFXSdbTable[3]; //! Table name of the [DAQ, DCS, HLT] FXS database
187 Int_t fMaxRetries; // number of retries of a failed preprocessor
189 Int_t fPPTimeOut; // timeout until a preprocessor is killed
190 Int_t fPPMaxMem; // maximum allowed memory until a preprocessor is killed
192 TMap fDetectorMap; //! Map of the detector-by-detector configuration
193 TObjArray fDetectorList; //! List of detectors with valid configuration
195 TString fShuttleInstanceHost; //! Instance of the SHUTTLE
196 TObjArray fProcessedDetectors; //! list of the detector to be processed by this machine
197 Bool_t fProcessAll; //! flag indicating that all detectors will be processed
198 Bool_t fIsValid; //! flag for the validity of the configuration
200 ClassDef(AliShuttleConfig, 0);