]>
Commit | Line | Data |
---|---|---|
1 | #ifndef ALI_SHUTTLE_CONFIG_H | |
2 | #define ALI_SHUTTLE_CONFIG_H | |
3 | ||
4 | /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * | |
5 | * See cxx source for full Copyright notice */ | |
6 | ||
7 | /* $Id$ */ | |
8 | ||
9 | // | |
10 | // This class keeps the AliShuttle configuration. | |
11 | // It reads the configuration for LDAP server. | |
12 | // For more info see AliShuttleConfig.cxx | |
13 | // | |
14 | ||
15 | #include <TObject.h> | |
16 | #include <TString.h> | |
17 | #include <TObjArray.h> | |
18 | #include <TMap.h> | |
19 | #include <TLDAPServer.h> | |
20 | ||
21 | class AliShuttleConfig: public TObject { | |
22 | public: | |
23 | enum RunMode {kTest=0, kProd}; | |
24 | enum SystemCode { kDAQ = 0, kDCS, kHLT, kDQM, kGlobal, kAmanda}; | |
25 | ||
26 | AliShuttleConfig(const char* host, Int_t port = LDAP_PORT, | |
27 | const char* binddn = 0, const char* password = 0, | |
28 | const char* basedn = "o=alice,dc=cern,dc=ch"); | |
29 | virtual ~AliShuttleConfig(); | |
30 | ||
31 | Bool_t IsValid() const {return fIsValid;}; | |
32 | ||
33 | const char* GetConfigHost() const {return fConfigHost.Data();} | |
34 | ||
35 | const char* GetAlienPath() const {return fAlienPath.Data();} | |
36 | ||
37 | const char* GetDAQlbHost() const {return fDAQlbHost.Data();} | |
38 | UInt_t GetDAQlbPort() const {return fDAQlbPort;} | |
39 | const char* GetDAQlbUser() const {return fDAQlbUser.Data();} | |
40 | const char* GetDAQlbPass() const {return fDAQlbPass.Data();} | |
41 | const char* GetDAQlbDB() const {return fDAQlbDB.Data();} | |
42 | const char* GetDAQlbTable() const {return fDAQlbTable.Data();} | |
43 | const char* GetShuttlelbTable() const {return fShuttlelbTable.Data();} | |
44 | const char* GetRunTypelbTable() const {return fRunTypelbTable.Data();} | |
45 | ||
46 | const char* GetFXSHost(Int_t sys) const {return fFXSHost[sys].Data();} | |
47 | UInt_t GetFXSPort(Int_t sys) const {return fFXSPort[sys];} | |
48 | const char* GetFXSUser(Int_t sys) const {return fFXSUser[sys].Data();} | |
49 | const char* GetFXSPass(Int_t sys) const {return fFXSPass[sys].Data();} | |
50 | const char* GetFXSBaseFolder(Int_t sys) const {return fFXSBaseFolder[sys].Data();} | |
51 | ||
52 | const char* GetFXSdbHost(Int_t sys) const {return fFXSdbHost[sys].Data();} | |
53 | UInt_t GetFXSdbPort(Int_t sys) const {return fFXSdbPort[sys];} | |
54 | const char* GetFXSdbUser(Int_t sys) const {return fFXSdbUser[sys].Data();} | |
55 | const char* GetFXSdbPass(Int_t sys) const {return fFXSdbPass[sys].Data();} | |
56 | const char* GetFXSdbName(Int_t sys) const {return fFXSdbName[sys].Data();} | |
57 | const char* GetFXSdbTable(Int_t sys) const {return fFXSdbTable[sys].Data();} | |
58 | ||
59 | const TObjArray* GetAdmins(Int_t sys) const; | |
60 | ||
61 | Bool_t SendMail() const { return fSendMail; } | |
62 | ||
63 | Int_t GetMaxRetries() const { return fMaxRetries; } | |
64 | ||
65 | Int_t GetPPTimeOut() const { return fPPTimeOut; } | |
66 | Int_t GetDCSTimeOut() const { return fDCSTimeOut; } | |
67 | Int_t GetDCSRetries() const { return fDCSRetries; } | |
68 | UInt_t GetDCSQueryOffset() const { return fDCSQueryOffset; } | |
69 | UInt_t GetDCSDelay() const { return fDCSDelay; } | |
70 | Int_t GetPPMaxMem() const { return fPPMaxMem; } | |
71 | ||
72 | const char* GetTerminateFilePath() const { return fTerminateFilePath; } | |
73 | ||
74 | Bool_t KeepDCSMap() const { return fKeepDCSMap; } | |
75 | Bool_t KeepTempFolder() const { return fKeepTempFolder; } | |
76 | ||
77 | ||
78 | const char* GetMonitorHost() const {return fMonitorHost.Data();} | |
79 | const char* GetMonitorTable() const {return fMonitorTable.Data();} | |
80 | ||
81 | Int_t GetTriggerWait() const {return fTriggerWait;} | |
82 | const char* GetShuttleFileSystem() const {return fShuttleFileSystem.Data();} | |
83 | Int_t GetFreeDiskWarningThreshold() const {return fFreeDiskWarningThreshold;} | |
84 | Int_t GetFreeDiskFatalThreshold() const {return fFreeDiskFatalThreshold;} | |
85 | ||
86 | RunMode GetRunMode() const {return fRunMode;} | |
87 | ||
88 | const TObjArray* GetDetectors() const; | |
89 | ||
90 | Bool_t HasDetector(const char* detector) const; | |
91 | ||
92 | Int_t GetNServers(const char* detector) const; | |
93 | ||
94 | const char* GetDCSHost(const char* detector, Int_t iServ) const; | |
95 | Int_t GetDCSPort(const char* detector, Int_t iServ) const; | |
96 | ||
97 | Int_t GetMultiSplit(const char* detector, Int_t iServ) const; | |
98 | ||
99 | const TObjArray* GetDCSAliases(const char* detector, Int_t iServ) const; | |
100 | const TObjArray* GetDCSDataPoints(const char* detector, Int_t iServ) const; | |
101 | const TObjArray* GetCompactDCSAliases(const char* detector, Int_t iServ) const; | |
102 | const TObjArray* GetCompactDCSDataPoints(const char* detector, Int_t iServ) const; | |
103 | ||
104 | const TObjArray* GetResponsibles(const char* detector) const; | |
105 | Bool_t StrictRunOrder(const char* detector) const; | |
106 | ||
107 | void SetProcessAll(Bool_t flag=kTRUE) {fProcessAll=flag;} | |
108 | Bool_t ProcessAll() const {return fProcessAll;} | |
109 | ||
110 | Bool_t HostProcessDetector(const char* detector) const; | |
111 | ||
112 | virtual void Print(Option_t* option = NULL) const; | |
113 | ||
114 | private: | |
115 | ||
116 | class AliShuttleDCSConfigHolder: public TObject { | |
117 | public: | |
118 | AliShuttleDCSConfigHolder(const TLDAPEntry* entry); | |
119 | ~AliShuttleDCSConfigHolder(); | |
120 | ||
121 | const char* GetDCSHost() const {return fDCSHost;} | |
122 | Int_t GetDCSPort() const {return fDCSPort;} | |
123 | Int_t GetMultiSplit() const {return fMultiSplit;} | |
124 | ||
125 | const TObjArray* GetDCSAliases() const {return fDCSAliases;} | |
126 | const TObjArray* GetDCSDataPoints() const {return fDCSDataPoints;} | |
127 | const TObjArray* GetCompactDCSAliases() const {return fDCSAliasesComp;} | |
128 | const TObjArray* GetCompactDCSDataPoints() const {return fDCSDataPointsComp;} | |
129 | ||
130 | void ExpandAndAdd(TObjArray* target, const char* entry); | |
131 | Bool_t IsValid() const {return fIsValid;} | |
132 | ||
133 | private: | |
134 | AliShuttleDCSConfigHolder(const AliShuttleDCSConfigHolder& other); // not implemented | |
135 | AliShuttleDCSConfigHolder& operator= (const AliShuttleDCSConfigHolder& other); // not implemented | |
136 | ||
137 | TString fDCSHost; // Host name of the DCS server | |
138 | Int_t fDCSPort; // port of the DCS server | |
139 | Int_t fMultiSplit; // N. of DPs to be queried in each query chunk | |
140 | TObjArray* fDCSAliases; // List of DCS aliases to be retrieved | |
141 | TObjArray* fDCSDataPoints; // List of DCS data points to be retrieved | |
142 | TObjArray* fDCSAliasesComp; // Compact list of DCS aliases to be printed | |
143 | TObjArray* fDCSDataPointsComp; // Compact list of DCS data points to be printed | |
144 | Bool_t fIsValid; // flag for the validity of the configuration | |
145 | ||
146 | ClassDef(AliShuttleDCSConfigHolder, 0); | |
147 | }; | |
148 | ||
149 | class AliShuttleDetConfigHolder: public TObject { | |
150 | public: | |
151 | AliShuttleDetConfigHolder(const TLDAPEntry* entry); | |
152 | ~AliShuttleDetConfigHolder(); | |
153 | ||
154 | const char* GetDetector() const {return fDetector.Data();} | |
155 | const TObjArray* GetDCSConfig() const {return fDCSConfig;} | |
156 | void AddDCSConfig(AliShuttleDCSConfigHolder* holder); | |
157 | ||
158 | Int_t GetNServers() const {return fDCSConfig ? fDCSConfig->GetEntries() : 0;} | |
159 | ||
160 | const char* GetDCSHost(Int_t iServ) const; | |
161 | Int_t GetDCSPort(Int_t iServ) const; | |
162 | Int_t GetMultiSplit(Int_t iServ) const; | |
163 | ||
164 | const TObjArray* GetDCSAliases(Int_t iServ) const; | |
165 | const TObjArray* GetDCSDataPoints(Int_t iServ) const; | |
166 | const TObjArray* GetCompactDCSAliases(Int_t iServ) const; | |
167 | const TObjArray* GetCompactDCSDataPoints(Int_t iServ) const; | |
168 | ||
169 | const TObjArray* GetResponsibles() const {return fResponsibles;} | |
170 | Bool_t IsValid() const {return fIsValid;} | |
171 | Bool_t SkipDCSQuery() const {return fSkipDCSQuery;} | |
172 | Bool_t StrictRunOrder() const {return fStrictRunOrder;} | |
173 | ||
174 | private: | |
175 | AliShuttleDetConfigHolder(const AliShuttleDetConfigHolder& other); // not implemented | |
176 | AliShuttleDetConfigHolder& operator= (const AliShuttleDetConfigHolder& other); // not implemented | |
177 | ||
178 | TString fDetector; // Detector name | |
179 | TObjArray* fDCSConfig; // Array of DCS configuration objects (AliShuttleDCSConfigHolder) | |
180 | TObjArray* fResponsibles; // List of email addresses of the detector's responsible(s) | |
181 | Bool_t fIsValid; // flag for the validity of the configuration | |
182 | Bool_t fSkipDCSQuery; // flag - if TRUE (-> DCS config empty) skip DCS archive data query | |
183 | Bool_t fStrictRunOrder; // flag - if TRUE connect data in a strict run ordering | |
184 | ||
185 | ClassDef(AliShuttleDetConfigHolder, 0); | |
186 | }; | |
187 | ||
188 | ||
189 | AliShuttleConfig(const AliShuttleConfig& other); | |
190 | AliShuttleConfig& operator= (const AliShuttleConfig& other); | |
191 | UInt_t SetGlobalConfig(TList* globalList); | |
192 | UInt_t SetSysConfig(TList* sysList); | |
193 | UInt_t SetPasswords(); | |
194 | UInt_t SetDetConfig(TList* detList, TList* dcsList); | |
195 | UInt_t SetHostConfig(TList* hostList); | |
196 | ||
197 | TString fConfigHost; // Host of the Shuttle configuration LDAP server | |
198 | ||
199 | TString fAlienPath; // Alien Path for CDB/Reference objs in the Alien catalogue | |
200 | ||
201 | TString fDAQlbHost; // Host of the DAQ logbook MySQL Server | |
202 | UInt_t fDAQlbPort; // port of the DAQ logbook MySQL Server | |
203 | TString fDAQlbUser; // username of the DAQ logbook MySQL Server | |
204 | TString fDAQlbPass; // password of the DAQ logbook MySQL Server | |
205 | TString fDAQlbDB; // DB name of the DAQ logbook MySQL Server | |
206 | TString fDAQlbTable; // Table name of the DAQ logbook | |
207 | TString fShuttlelbTable; // Table name of the Shuttle logbook | |
208 | TString fRunTypelbTable; // Table name of the Run typr logbook | |
209 | TString fPasswdFilePath; // Path for the local file where the passwords are stored | |
210 | ||
211 | TString fFXSHost[4]; // Host of the [DAQ, DCS, HLT, DQM] File eXchange Server | |
212 | UInt_t fFXSPort[4]; // Port of the [DAQ, DCS, HLT, DQM] File eXchange Server | |
213 | TString fFXSUser[4]; // username of the [DAQ, DCS, HLT, DQM] File eXchange Server | |
214 | TString fFXSPass[4]; // password of the [DAQ, DCS, HLT, DQM] File eXchange Server | |
215 | TString fFXSBaseFolder[4]; // base folder of the [DAQ, DCS, HLT, DQM] File eXchange Server | |
216 | ||
217 | TString fFXSdbHost[4]; // Host of the [DAQ, DCS, HLT, DQM] FXS database | |
218 | UInt_t fFXSdbPort[4]; // Port of the [DAQ, DCS, HLT, DQM] FXS database | |
219 | TString fFXSdbUser[4]; // username of the [DAQ, DCS, HLT, DQM] FXS database | |
220 | TString fFXSdbPass[4]; // password of the [DAQ, DCS, HLT, DQM] FXS database | |
221 | TString fFXSdbName[4]; // name of the [DAQ, DCS, HLT, DQM] FXS database | |
222 | TString fFXSdbTable[4]; // Table name of the [DAQ, DCS, HLT, DQM] FXS database | |
223 | ||
224 | TString fTerminateFilePath; // File for inter-process communcation to terminate the Shuttle | |
225 | ||
226 | Int_t fMaxRetries; // number of retries of a failed preprocessor | |
227 | ||
228 | Int_t fPPTimeOut; // timeout until a preprocessor is killed | |
229 | Int_t fDCSTimeOut; // timeout until the query to DCS is terminated | |
230 | Int_t fDCSRetries; // number of retries until the query to DCS connection is terminated | |
231 | UInt_t fDCSQueryOffset; // offset for the DCS DPs query, to be subracted from the StartTime and | |
232 | // added to the EndTime | |
233 | UInt_t fDCSDelay; // delay to make the query to DCS | |
234 | Int_t fPPMaxMem; // maximum allowed memory until a preprocessor is killed | |
235 | ||
236 | TString fMonitorHost; // host of the MonaLisa monitoring server | |
237 | TString fMonitorTable; // Monalisa's SHUTTLE table name | |
238 | ||
239 | Int_t fTriggerWait; // time to wait for DIM trigger before starting new collection | |
240 | TString fShuttleFileSystem; // path of the Shuttle file system | |
241 | Int_t fFreeDiskWarningThreshold; // threshold for free space in the Shuttle file system to send a mail to the responsibles | |
242 | Int_t fFreeDiskFatalThreshold; // threshold for free space in the Shuttle file system to send a mail to the responsibles and terminate the Shuttle | |
243 | RunMode fRunMode; // Working mode (0=test; 1=prod) | |
244 | ||
245 | TMap fDetectorMap; // Map of the detector-by-detector configuration | |
246 | TObjArray fDetectorList; // List of detectors with valid configuration | |
247 | ||
248 | TObjArray *fAdmin[6]; // Array of system administrators' email addresses (DAQ, DCS, HLT, DQM, Global, Amanda) | |
249 | ||
250 | TString fShuttleInstanceHost; // Instance of the SHUTTLE | |
251 | TObjArray fProcessedDetectors; // list of the detector to be processed by this machine | |
252 | ||
253 | Bool_t fKeepDCSMap; // Flag to keep DCS map also in case of success | |
254 | Bool_t fKeepTempFolder; // Flag to keep temp folder also in case of success | |
255 | ||
256 | Bool_t fSendMail; // Send mail flag | |
257 | ||
258 | Bool_t fProcessAll; // flag indicating that all detectors will be processed | |
259 | Bool_t fIsValid; // flag for the validity of the configuration | |
260 | ||
261 | ClassDef(AliShuttleConfig, 0); | |
262 | }; | |
263 | ||
264 | #endif | |
265 |