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;
34 class AliShuttle: public AliShuttleInterface {
36 enum DCSType {kAlias=0, kDP};
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;
55 virtual UInt_t Store(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
56 Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
57 virtual UInt_t StoreReferenceData(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData);
58 virtual const char* GetFile(Int_t system, const char* detector,
59 const char* id, const char* source);
60 virtual TList* GetFileSources(Int_t system, const char* detector, const char* id);
61 virtual const char* GetRunParameter(const char* lbEntry);
62 virtual void Log(const char* detector, const char* message);
64 static TString GetMainCDB () {return fgkMainCDB;}
65 static void SetMainCDB (TString mainCDB) {fgkMainCDB = mainCDB;}
66 static TString GetLocalCDB () {return fgkLocalCDB;}
67 static void SetLocalCDB (TString localCDB) {fgkLocalCDB = localCDB;}
69 static TString GetMainRefStorage() {return fgkMainRefStorage;}
70 static void SetMainRefStorage (TString mainRefStorage) {fgkMainRefStorage = mainRefStorage;}
71 static TString GetLocalRefStorage() {return fgkLocalRefStorage;}
72 static void SetLocalRefStorage (TString localRefStorage) {fgkLocalRefStorage = localRefStorage;}
74 //TODO Test only, remove later !
75 void SetProcessDCS(Bool_t process) {fgkProcessDCS = process;}
76 void SetLogbookEntry(AliShuttleLogbookEntry* entry) {fLogbookEntry=entry;}
78 static void SetShuttleTempDir (const char* tmpDir);
79 static const char* GetShuttleTempDir() {return fgkShuttleTempDir.Data();}
80 static void SetShuttleLogDir (const char* logDir);
81 static const char* GetShuttleLogDir() {return fgkShuttleLogDir.Data();}
83 Bool_t Connect(Int_t system);
86 AliShuttle(const AliShuttle& other);
87 AliShuttle& operator= (const AliShuttle& other);
89 UInt_t ProcessCurrentDetector();
91 AliShuttleLogbookEntry* QueryRunParameters(Int_t run);
92 Bool_t QueryShuttleLogbook(const char* whereClause, TObjArray& entries);
93 Bool_t RetrieveConditionsData(const TObjArray& shuttleLogbookEntries);
95 Bool_t GetValueSet(const char* host, Int_t port, const char* alias,
96 TObjArray* result, DCSType type);
98 const char* GetDAQFileName(const char* detector, const char* id, const char* source);
99 Bool_t RetrieveDAQFile(const char* daqFileName, const char* localFileName);
100 TList* GetDAQFileSources(const char* detector, const char* id);
101 Bool_t UpdateDAQTable();
103 const char* GetDCSFileName(const char* detector, const char* id, const char* source);
104 // Bool_t RetrieveDCSFile(const char* daqFileName const char* localFileName);
105 TList* GetDCSFileSources(const char* detector, const char* id);
106 // Bool_t UpdateDCSTable();
108 const char* GetHLTFileName(const char* detector, const char* id, const char* source);
109 Bool_t RetrieveHLTFile(const char* hltFileName, const char* localFileName);
110 TList* GetHLTFileSources(const char* detector, const char* id);
111 Bool_t UpdateHLTTable();
113 UInt_t WriteToCDB(const char* mainUri, const char* localUri,
114 const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
115 Int_t validityStart = 0, Bool_t validityInfinite = kFALSE);
117 Bool_t TryToStoreAgain();
118 Bool_t TryToStoreAgain(TString& storageType);
120 AliShuttleStatus* ReadShuttleStatus();
121 Bool_t WriteShuttleStatus(AliShuttleStatus* status);
122 Bool_t ContinueProcessing();
123 void UpdateShuttleStatus(AliShuttleStatus::Status newStatus, Bool_t increaseCount = kFALSE);
124 Bool_t UpdateShuttleLogbook(const char* detector, const char* status=0);
127 void SetLastAction(const char* action);
129 const AliShuttleConfig* fConfig; // pointer to configuration object
131 static TString fgkMainCDB; // URI of the main (Grid) CDB storage
132 static TString fgkLocalCDB; //! URI of the local backup CDB storage
133 static TString fgkMainRefStorage; // URI of the main (Grid) REFERENCE storage
134 static TString fgkLocalRefStorage; // URI of the local REFERENCE storage
135 static TString fgkShuttleTempDir; // base path of SHUTTLE temp folder
136 static TString fgkShuttleLogDir; // path of SHUTTLE log folder
138 UInt_t fTimeout; // DCS server connection timeout parameter
139 Int_t fRetries; // Number of DCS server connection retries
141 TMap fPreprocessorMap; // list of detector Preprocessors ("DET", "Preprocessor")
143 AliShuttleLogbookEntry* fLogbookEntry; //! current Shuttle logbook entry
144 TString fCurrentDetector; // current detector
146 TSQLServer *fServer[4]; // pointer to the three FXS + Run & Shuttle logbook servers
147 Bool_t fFXSCalled[3]; // FXS call status
148 TList fFXSlist[3]; // List of files retrieved from each FXS
150 AliCDBEntry* fStatusEntry; // last CDB entry containing a AliShuttleStatus retrieved
151 Bool_t fGridError; // Grid storage error flag
153 TMutex* fMonitoringMutex; // mutex to lock the monitoring class members
154 UInt_t fLastActionTime; // time of last action for monitoring
155 TString fLastAction; // string description for last action
157 Bool_t fFirstUnprocessed[AliShuttleInterface::kNDetectors]; // array of flags for first unprocessed dets
159 //TODO Test only, remove later !
160 static Bool_t fgkProcessDCS; // flag to enable DCS archive data processing
162 ClassDef(AliShuttle, 0);