4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
11 // This class is the main manager for
12 // AliShuttle. It organizes the data retrieval
13 // from DCS and call the interface methods of
21 #include "AliShuttleInterface.h"
22 #include "AliShuttleStatus.h"
25 class AliShuttleConfig;
26 class AliShuttleLogbookEntry;
27 class AliPreprocessor;
30 class TMonaLisaWriter;
32 class AliShuttle: public AliShuttleInterface {
34 enum DCSType {kAlias=0, kDP};
35 enum TestMode { kNone = 0, kSkipDCS = 1, kErrorDCS = 2, kErrorFXSSources = 4, kErrorFXSFiles = 8, kErrorOCDB = 16, kErrorStorage = 32, kErrorGrid = 64 };
36 enum EMailTarget { kDCSEMail = 0, kFXSEMail, kPPEMail };
38 AliShuttle(const AliShuttleConfig* config, UInt_t timeout = 5000, Int_t retries = 5);
39 virtual ~AliShuttle();
41 virtual void RegisterPreprocessor(AliPreprocessor* preprocessor);
43 Bool_t Collect(Int_t run = -1);
45 Bool_t Process(AliShuttleLogbookEntry* entry);
47 // monitoring functions
48 ULong_t GetTimeOfLastAction() const;
49 const TString GetLastAction() const;
51 Int_t GetCurrentRun() const;
52 UInt_t GetCurrentStartTime() const;
53 UInt_t GetCurrentEndTime() const;
54 UInt_t GetCurrentYear() const;
56 const char* GetLHCPeriod() const;
58 virtual Bool_t Store(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
59 Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
60 virtual Bool_t StoreReferenceData(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData);
61 virtual Bool_t StoreReferenceFile(const char* detector, const char* localFile, const char* gridFileName);
62 virtual Bool_t StoreRunMetadataFile(const char* localFile, const char* gridFileName);
63 virtual const char* GetFile(Int_t system, const char* detector,
64 const char* id, const char* source);
65 virtual TList* GetFileSources(Int_t system, const char* detector, const char* id = 0);
66 virtual TList* GetFileIDs(Int_t system, const char* detector, const char* source);
67 virtual const char* GetRunParameter(const char* lbEntry);
68 virtual UInt_t GetStartTimeDCSQuery();
69 virtual UInt_t GetEndTimeDCSQuery();
70 virtual AliCDBEntry* GetFromOCDB(const char* detector, const AliCDBPath& path);
71 virtual const char* GetRunType();
72 virtual Bool_t GetHLTStatus();
73 virtual const char* GetTriggerConfiguration();
74 virtual const char* GetCTPTimeParams();
75 virtual const char* GetTriggerDetectorMask();
76 virtual void Log(const char* detector, const char* message, UInt_t level=3);
78 void SetLogbookEntry(AliShuttleLogbookEntry* entry) {fLogbookEntry=entry;}
80 void SetTestMode(TestMode testMode) { fTestMode = testMode; }
81 void SetReadTestModeFromLog(Bool_t flag) { fReadTestMode = flag; }
83 Bool_t Connect(Int_t system);
85 static void SetMainCDB (TString mainCDB) {fgkMainCDB = mainCDB;}
86 static void SetLocalCDB (TString localCDB) {fgkLocalCDB = localCDB;}
88 static void SetMainRefStorage (TString mainRefStorage) {fgkMainRefStorage = mainRefStorage;}
89 static void SetLocalRefStorage (TString localRefStorage) {fgkLocalRefStorage = localRefStorage;}
91 static void SetShuttleTempDir (const char* tmpDir);
92 static void SetShuttleLogDir (const char* logDir);
95 AliShuttle(const AliShuttle& other);
96 AliShuttle& operator= (const AliShuttle& other);
98 Int_t ProcessCurrentDetector();
100 AliShuttleLogbookEntry* QueryRunParameters(Int_t run);
101 Bool_t QueryShuttleLogbook(const char* whereClause, TObjArray& entries);
102 void CountOpenRuns();
103 Bool_t RetrieveConditionsData(const TObjArray& shuttleLogbookEntries);
105 TMap* GetValueSet(const char* host, Int_t port, const TSeqCollection* entries,
106 DCSType type, Int_t valueSet);
108 Bool_t RetrieveFile(UInt_t system, const char* daqFileName, const char* localFileName);
110 Bool_t UpdateTable();
111 Bool_t UpdateTableSkippedCase(const char* detector="ALL");
112 Bool_t UpdateTableFailCase();
114 Bool_t StoreLocally(const TString& localUri, const AliCDBPath& path, TObject* object,
115 AliCDBMetaData* metaData, Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
118 Int_t StoreOCDB(const TString& uri);
119 Bool_t CopyFileLocally(const char* localFile, const TString& target);
120 Bool_t CopyFilesToGrid(const char* type);
121 void CleanLocalStorage(const TString& uri);
122 Bool_t CleanReferenceStorage(const char* detector);
123 void RemoveFile(const char* filename);
124 const char* GetRefFilePrefix(const char* base, const char* detector);
126 AliShuttleStatus* ReadShuttleStatus();
127 Bool_t WriteShuttleStatus(AliShuttleStatus* status);
128 Bool_t ContinueProcessing();
129 void UpdateShuttleStatus(AliShuttleStatus::Status newStatus, Bool_t increaseCount = kFALSE);
130 Bool_t UpdateShuttleLogbook(const char* detector, const char* status=0);
131 Bool_t SendMail(EMailTarget target, Int_t system = -1);
132 Int_t GetMem(Int_t pid);
134 TString GetLogFileName(const char* detector) const;
136 void SetLastAction(const char* action);
139 void SendMLDetInfo();
140 void SendMLRunInfo(const char* status);
141 virtual Bool_t TouchFile();
143 const AliShuttleConfig* fConfig; // pointer to configuration object
145 UInt_t fTimeout; // DCS server connection timeout parameter
146 Int_t fRetries; // Number of DCS server connection retries
148 TMap fPreprocessorMap; // list of detector Preprocessors ("DET", "Preprocessor")
150 AliShuttleLogbookEntry* fLogbookEntry; //! current Shuttle logbook entry
151 TString fCurrentDetector; // current detector
152 Bool_t fFirstProcessing; // processing this detector the first time in this run
154 TSQLServer *fServer[4]; // pointer to the three FXS + Run & Shuttle logbook servers
155 Bool_t fFXSCalled[3]; // FXS call status
156 TList fFXSlist[3]; // List of files retrieved from each FXS
157 Int_t fFXSError; // Variable to keep track of any FXS errors; contains -1 for no error, kDAQ, kDCS, kHLT otherwise
159 AliCDBEntry* fStatusEntry; // last CDB entry containing a AliShuttleStatus retrieved
161 TMutex* fMonitoringMutex; // mutex to lock the monitoring class members
162 UInt_t fLastActionTime; // time of last action for monitoring
163 TString fLastAction; // string description for last action
165 Bool_t fFirstUnprocessed[AliShuttleInterface::kNDetectors]; // array of flags for first unprocessed dets
167 TMonaLisaWriter* fMonaLisa; // ML instance that sends the processing information
169 TestMode fTestMode; // sets test mode flags, that e.g. simulate a dcs error etc.
170 Bool_t fReadTestMode; // Reads the test mode from the log entry of the given run (only for test)
172 Bool_t fOutputRedirected; // is the output redirected to a file
174 ClassDef(AliShuttle, 0);