]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - SHUTTLE/AliShuttle.h
New developments of the analysis framework - selectorised version of the manager...
[u/mrichter/AliRoot.git] / SHUTTLE / AliShuttle.h
index 17885f2ff6626b95c21ce767f74edcafef8067fe..037d17690ce77033e6c2d3c2e59063d7a3e38d08 100644 (file)
 
 #include <TMap.h>
 #include <TString.h>
+#include <TList.h>
 
 #include "AliShuttleInterface.h"
+#include "AliShuttleStatus.h"
 
 class TObject;
 class AliShuttleConfig;
+class AliShuttleLogbookEntry;
 class AliPreprocessor;
 class AliCDBMetaData;
+class TSQLServer;
+class AliCDBEntry;
+class AliCDBPath;
+class TMutex;
 
 class AliShuttle: public AliShuttleInterface {
 public:
@@ -31,50 +38,118 @@ public:
 
        virtual void RegisterPreprocessor(AliPreprocessor* preprocessor);
 
-       Bool_t Process(Int_t run, UInt_t startTime, UInt_t endTime);
-       Bool_t Process(Int_t run, UInt_t startTime, UInt_t endTime,
-               const char* detector);
+       Bool_t Collect(Int_t run = -1);
 
-       Int_t GetCurrentRun() const {return fCurrentRun;};
-       UInt_t GetCurrentStartTime() const {return fCurrentStartTime;};
-       UInt_t GetCurrentEndTime() const {return fCurrentEndTime;};
+       Bool_t Process(AliShuttleLogbookEntry* entry);
 
-       virtual UInt_t Store(const char* detector, TObject* object, AliCDBMetaData* metaData);
+       // monitoring functions
+       ULong_t GetTimeOfLastAction() const;
+       const TString GetLastAction() const;
+
+       Int_t GetCurrentRun() const;
+       UInt_t GetCurrentStartTime() const;
+       UInt_t GetCurrentEndTime() 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 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 const char* GetRunParameter(const char* lbEntry);
        virtual void Log(const char* detector, const char* message);
 
-       static TString GetLocalURI () {return fgkLocalUri;}
-       static void SetLocalURI (TString localUri) {fgkLocalUri = localUri;}
+       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;}
+       void SetLogbookEntry(AliShuttleLogbookEntry* entry) {fLogbookEntry=entry;}
+
+       static const char* GetShuttleTempDir() {return fgkShuttleTempDir;}
+
+       Bool_t Connect(Int_t system);
 
 private:
+       AliShuttle(const AliShuttle& other);
+       AliShuttle& operator= (const AliShuttle& other);
+
+       UInt_t ProcessCurrentDetector();
+
+       AliShuttleLogbookEntry* QueryRunParameters(Int_t run);
+       Bool_t QueryShuttleLogbook(const char* whereClause, TObjArray& entries);
+       Bool_t RetrieveConditionsData(const TObjArray& shuttleLogbookEntries);
+
+       Bool_t GetValueSet(const char* host, Int_t port, const char* alias, TObjArray* result);
 
-       AliShuttle(const AliShuttle& other);    
-       AliShuttle& operator= (const AliShuttle& other);        
+       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();
 
-       static TString fgkLocalUri;     // URI of the local backup storage location 
+       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);
 
-       void ClearLog() {fLog = "";}
-       void StoreLog(Int_t run);
-       const AliShuttleConfig* fConfig;
+       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);
 
-//     AliCDBStorage* fLocalStorage;
+       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);
+       
+       void SetLastAction(const char* action);
+
+       const AliShuttleConfig* fConfig;        // pointer to configuration object
+
+       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
 
        TMap fPreprocessorMap;  // list of detector Preprocessors ("DET", "Preprocessor")
 
-       Int_t fCurrentRun;              // run currenty processed
-       UInt_t fCurrentStartTime;       // Run Start time
-       UInt_t fCurrentEndTime;         // Run end time
+       AliShuttleLogbookEntry* fLogbookEntry;   //! current Shuttle logbook entry
+       TString fCurrentDetector; // current detector
+
+       TSQLServer *fServer[4];         // pointer to the three FES + Run & Shuttle logbook servers
+       Bool_t fFESCalled[3];           // FES call status
+       TList  fFESlist[3];             // List of files retrieved from each FES
+
+       AliCDBEntry* fStatusEntry; // last CDB entry containing a AliShuttleStatus retrieved
+       Bool_t fGridError;         // Grid storage error flag
+
+       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
 
-       TString fLog;                   // log message
+       //TODO Test only, remove later !
+       static Bool_t fgkProcessDCS; // flag to enable DCS archive data processing
 
-       Bool_t GetValueSet(const char* host, Int_t port, const char* alias,
-                       TObjArray& result);
-       
        ClassDef(AliShuttle, 0);
 };