]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - SHUTTLE/AliShuttle.h
runs are considered by the shuttle that have (ecs_status = true) OR (events > 1)
[u/mrichter/AliRoot.git] / SHUTTLE / AliShuttle.h
index d94378f315f2e1c4e006b3f8cd20c8866ce71d67..51d215572e5b6d0ea7927c299fe838810566b767 100644 (file)
@@ -33,6 +33,7 @@ class AliShuttle: public AliShuttleInterface {
 public:
        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();
@@ -67,6 +68,7 @@ public:
        virtual AliCDBEntry* GetFromOCDB(const char* detector, const AliCDBPath& path);
        virtual const char* GetRunType();
        virtual Bool_t GetHLTStatus();
+       virtual const char* GetTriggerConfiguration(); 
        virtual void Log(const char* detector, const char* message);
 
        void SetLogbookEntry(AliShuttleLogbookEntry* entry) {fLogbookEntry=entry;}
@@ -89,10 +91,11 @@ private:
        AliShuttle(const AliShuttle& other);
        AliShuttle& operator= (const AliShuttle& other);
 
-       Bool_t ProcessCurrentDetector();
+       Int_t ProcessCurrentDetector();
 
        AliShuttleLogbookEntry* QueryRunParameters(Int_t run);
        Bool_t QueryShuttleLogbook(const char* whereClause, TObjArray& entries);
+       void CountOpenRuns();
        Bool_t RetrieveConditionsData(const TObjArray& shuttleLogbookEntries);
 
        TMap* GetValueSet(const char* host, Int_t port, const TSeqCollection* entries,
@@ -107,7 +110,7 @@ private:
                                AliCDBMetaData* metaData, Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
 
        Bool_t StoreOCDB();
-       Bool_t StoreOCDB(const TString& uri);
+       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);
@@ -120,14 +123,16 @@ private:
        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();
-       Bool_t SendMailToDCS();
+       Bool_t SendMail(EMailTarget target, Int_t system = -1);
        
        TString GetLogFileName(const char* detector) const;
 
        void SetLastAction(const char* action);
        
-       void SendMLInfo();
+       void SendAlive();
+       void SendMLDetInfo();
+       void SendMLRunInfo(const char* status);
+       virtual Bool_t TouchFile();
 
        const AliShuttleConfig* fConfig;        // pointer to configuration object
 
@@ -138,10 +143,12 @@ 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[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