]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - SHUTTLE/AliShuttle.h
fix for bug #66294
[u/mrichter/AliRoot.git] / SHUTTLE / AliShuttle.h
index 6a13afd4d065041434f20391fc71ee1e678e2166..e304d6a71d282373af81a8f34ad34a79a892caf8 100644 (file)
@@ -25,110 +25,123 @@ class TObject;
 class AliShuttleConfig;
 class AliShuttleLogbookEntry;
 class AliPreprocessor;
-class AliCDBMetaData;
 class TSQLServer;
-class AliCDBEntry;
-class AliCDBPath;
+class TMutex;
+class TMonaLisaWriter;
 
 class AliShuttle: public AliShuttleInterface {
 public:
-       enum { kNDetectors=17 }; // number of subdetectors in ALICE
+       enum DCSType {kAlias=0, kDP};
+       enum TestMode { kNone = 0, kSkipDCS = 1, kErrorDCS = 2, kErrorFXSSources = 4, kErrorFXSFiles = 8, kErrorOCDB = 16, kErrorStorage = 32, kErrorGrid = 64 };
+       enum EMailTarget { kDCSEMail = 0, kFXSEMail, kPPEMail };
 
        AliShuttle(const AliShuttleConfig* config, UInt_t timeout = 5000, Int_t retries = 5);
        virtual ~AliShuttle();
 
        virtual void RegisterPreprocessor(AliPreprocessor* preprocessor);
 
-       Bool_t Collect(Int_t run);
-       Bool_t CollectNew();
-       Bool_t CollectAll();
+       Bool_t Collect(Int_t run = -1);
 
        Bool_t Process(AliShuttleLogbookEntry* entry);
 
+       // monitoring functions
+       ULong_t GetTimeOfLastAction() const;
+       const TString GetLastAction() const;
+
        Int_t GetCurrentRun() const;
        UInt_t GetCurrentStartTime() const;
        UInt_t GetCurrentEndTime() const;
+       UInt_t GetCurrentYear() const;
+       
+       const char* GetLHCPeriod() const;
 
-       virtual UInt_t Store(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
-                       Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
-       virtual UInt_t StoreReferenceData(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
+       virtual Bool_t Store(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
                        Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
+       virtual Bool_t StoreReferenceData(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData);
+       virtual Bool_t StoreReferenceFile(const char* detector, const char* localFile, const char* gridFileName);
+       virtual Bool_t StoreRunMetadataFile(const char* localFile, const char* gridFileName);
        virtual const char* GetFile(Int_t system, const char* detector,
                const char* id, const char* source);
-       virtual TList* GetFileSources(Int_t system, const char* detector, const char* id);
-       virtual void Log(const char* detector, const char* message);
+       virtual TList* GetFileSources(Int_t system, const char* detector, const char* id = 0);
+       virtual TList* GetFileIDs(Int_t system, const char* detector, const char* source);
+       virtual const char* GetRunParameter(const char* lbEntry);
+       virtual UInt_t GetStartTimeDCSQuery();
+       virtual UInt_t GetEndTimeDCSQuery();
+       virtual AliCDBEntry* GetFromOCDB(const char* detector, const AliCDBPath& path);
+       virtual const char* GetRunType();
+       virtual Bool_t GetHLTStatus();
+       virtual const char* GetTriggerConfiguration(); 
+       virtual const char* GetCTPTimeParams(); 
+       virtual const char* GetTriggerDetectorMask(); 
+       virtual void Log(const char* detector, const char* message, UInt_t level=3);
+
+       void SetLogbookEntry(AliShuttleLogbookEntry* entry) {fLogbookEntry=entry;}
+       
+       void SetTestMode(TestMode testMode) { fTestMode = testMode; }
+       void SetReadTestModeFromLog(Bool_t flag) { fReadTestMode = flag; }
+
+       Bool_t Connect(Int_t system);
 
-       static TString GetMainCDB () {return fgkMainCDB;}
        static void SetMainCDB (TString mainCDB) {fgkMainCDB = mainCDB;}
-       static TString GetLocalCDB () {return fgkLocalCDB;}
        static void SetLocalCDB (TString localCDB) {fgkLocalCDB = localCDB;}
 
-       static TString GetMainRefStorage() {return fgkMainRefStorage;}
        static void SetMainRefStorage (TString mainRefStorage) {fgkMainRefStorage = mainRefStorage;}
-       static TString GetLocalRefStorage() {return fgkLocalRefStorage;}
        static void SetLocalRefStorage (TString localRefStorage) {fgkLocalRefStorage = localRefStorage;}
 
-       //TODO Test only, remove later !
-       void SetProcessDCS(Bool_t process) {fgkProcessDCS = process;}
-
-       static const char* GetDetCode(const char* detector);
-       static const char* GetDetCode(UInt_t detPos);
-       static const Int_t GetDetPos(const char* detCode);
-       static const UInt_t NDetectors() {return kNDetectors;}
-       static const char* GetShuttleTempDir() {return fgkShuttleTempDir;}
-
-       Bool_t Connect(Int_t system);
+       static void SetShuttleTempDir (const char* tmpDir);
+       static void SetShuttleLogDir (const char* logDir);
 
 private:
        AliShuttle(const AliShuttle& other);
        AliShuttle& operator= (const AliShuttle& other);
 
-       UInt_t ProcessCurrentDetector();
+       Int_t ProcessCurrentDetector();
 
-       Bool_t QueryRunParameters(Int_t& run, UInt_t& startTime, UInt_t& endTime);
+       AliShuttleLogbookEntry* QueryRunParameters(Int_t run);
        Bool_t QueryShuttleLogbook(const char* whereClause, TObjArray& entries);
+       void CountOpenRuns();
        Bool_t RetrieveConditionsData(const TObjArray& shuttleLogbookEntries);
 
-       Bool_t GetValueSet(const char* host, Int_t port, const char* alias, TObjArray* result);
-
-       const char* GetDAQFileName(const char* detector, const char* id, const char* source);
-       Bool_t RetrieveDAQFile(const char* daqFileName, const char* localFileName);
-       TList* GetDAQFileSources(const char* detector, const char* id);
-       Bool_t UpdateDAQTable();
-
-       const char* GetDCSFileName(const char* detector, const char* id, const char* source);
-//     Bool_t RetrieveDCSFile(const char* daqFileName const char* localFileName);
-       TList* GetDCSFileSources(const char* detector, const char* id);
-
-       const char* GetHLTFileName(const char* detector, const char* id, const char* source);
-//     Bool_t RetrieveHLTFile(const char* daqFileName, const char* localFileName;
-       TList* GetHLTFileSources(const char* detector, const char* id);
-
-       UInt_t WriteToCDB(const char* mainUri, const char* localUri,
-                               const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
-                               Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
-
-       Bool_t TryToStoreAgain();
-       Bool_t TryToStoreAgain(TString& storageType);
-
-       AliShuttleStatus* ReadShuttleStatus();
-       Bool_t WriteShuttleStatus(AliShuttleStatus* status);
-       Bool_t ContinueProcessing();
-       void UpdateShuttleStatus(AliShuttleStatus::Status newStatus, Bool_t increaseCount = kFALSE);
-       Bool_t UpdateShuttleLogbook(const char* detector, const char* status=0);
+       TMap* GetValueSet(const char* host, Int_t port, const TSeqCollection* entries,
+                             DCSType type, Int_t valueSet);
+
+       Bool_t RetrieveFile(UInt_t system, const char* daqFileName, const char* localFileName);
+
+       Bool_t UpdateTable();
+       Bool_t UpdateTableSkippedCase(const char* detector="ALL");
+       Bool_t UpdateTableFailCase();
+
+       Bool_t StoreLocally(const TString& localUri, const AliCDBPath& path, TObject* object,
+                               AliCDBMetaData* metaData, Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
+
+       Bool_t StoreOCDB();
+       Int_t StoreOCDB(const TString& uri);
+       Bool_t CopyFileLocally(const char* localFile, const TString& target);
+       Bool_t CopyFilesToGrid(const char* type);
+       void CleanLocalStorage(const TString& uri);
+       Bool_t CleanReferenceStorage(const char* detector);
+       void RemoveFile(const char* filename);
+       const char* GetRefFilePrefix(const char* base, const char* detector);
+
+       AliShuttleStatus* ReadShuttleStatus();
+       Bool_t WriteShuttleStatus(AliShuttleStatus* status);
+       Bool_t ContinueProcessing();
+       void UpdateShuttleStatus(AliShuttleStatus::Status newStatus, Bool_t increaseCount = kFALSE);
+       Bool_t UpdateShuttleLogbook(const char* detector, const char* status=0);
+       Bool_t SendMail(EMailTarget target, Int_t system = -1);
+       Int_t GetMem(Int_t pid);
+       
+       TString GetLogFileName(const char* detector) const;
+
+       void SetLastAction(const char* action);
+       
+       void SendAlive();
+       void SendMLDetInfo();
+       void SendMLRunInfo(const char* status);
+       virtual Bool_t TouchFile();
 
        const AliShuttleConfig* fConfig;        // pointer to configuration object
 
-//     static const UInt_t fgkNDetectors = 17;                 //! number of detectors
-       static const char*  fgkDetectorName[kNDetectors];       //! names of detectors
-       static const char*  fgkDetectorCode[kNDetectors];       //! codes of detectors
-       static TString      fgkMainCDB;         // URI of the main (Grid) CDB storage
-       static TString      fgkLocalCDB;                //! URI of the local backup CDB storage
-       static TString      fgkMainRefStorage;  // URI of the main (Grid) REFERENCE storage
-       static TString      fgkLocalRefStorage; // URI of the local REFERENCE storage
-       static const char*  fgkShuttleTempDir;  // base path of SHUTTLE temp folder
-       static const char*  fgkShuttleLogDir;   // path of SHUTTLE log folder
-
        UInt_t fTimeout;        // DCS server connection timeout parameter
        Int_t fRetries;         // Number of DCS server connection retries
 
@@ -136,16 +149,27 @@ private:
 
        AliShuttleLogbookEntry* fLogbookEntry;   //! current Shuttle logbook entry
        TString fCurrentDetector; // current detector
+       Bool_t fFirstProcessing;  // processing this detector the first time in this run
 
-       TSQLServer *fServer[3];         // pointer to the three FS logbook servers
-       Bool_t fFESCalled[3];           // FES call status
-       TList  fFESlist[3];             // List of files retrieved from each FES
+       TSQLServer *fServer[4];         // pointer to the three FXS + Run & Shuttle logbook servers
+       Bool_t fFXSCalled[3];           // FXS call status
+       TList  fFXSlist[3];             // List of files retrieved from each FXS
+       Int_t  fFXSError;               // Variable to keep track of any FXS errors; contains -1 for no error, kDAQ, kDCS, kHLT otherwise
 
        AliCDBEntry* fStatusEntry; // last CDB entry containing a AliShuttleStatus retrieved
-       Bool_t fGridError;         // Grid storage error flag
 
-       //TODO Test only, remove later !
-       static Bool_t fgkProcessDCS; // flag to enable DCS archive data processing
+       TMutex* fMonitoringMutex;   // mutex to lock the monitoring class members
+       UInt_t fLastActionTime;    // time of last action for monitoring
+       TString fLastAction;       // string description for last action
+
+       Bool_t fFirstUnprocessed[AliShuttleInterface::kNDetectors];       // array of flags for first unprocessed dets
+
+       TMonaLisaWriter* fMonaLisa;  // ML instance that sends the processing information
+
+       TestMode fTestMode;          // sets test mode flags, that e.g. simulate a dcs error etc.
+       Bool_t fReadTestMode;        // Reads the test mode from the log entry of the given run (only for test)
+       
+       Bool_t fOutputRedirected;    // is the output redirected to a file
 
        ClassDef(AliShuttle, 0);
 };