1 #include "AliStorageServerThread.h"
2 #include "AliStorageTypes.h"
3 #include "AliESDEvent.h"
13 AliStorageServerThread::AliStorageServerThread() :
17 fDatabase = new AliStorageDatabase();
20 //load parameters from config file
21 ifstream configFile (GetConfigFilePath());
22 if (configFile.is_open())
26 while(configFile.good())
28 getline(configFile,line);
29 from = line.find("\"")+1;
30 to = line.find_last_of("\"");
31 if(line.find("STORAGE_PATH=")==0){
32 fStoragePath=line.substr(from,to-from);
35 if(configFile.eof()){configFile.clear();}
38 else{cout<<"SERVER -- Unable to open config file"<<endl;}
41 //start communication on socket
42 cout<<"Starting server's communication"<<endl;
46 AliStorageServerThread::~AliStorageServerThread()
48 cout<<"SERVER -- AliStorageServerThread destructor called";
49 if (fDatabase) {delete fDatabase;}
50 cout<<" --- OK"<<endl;
53 void AliStorageServerThread::StartCommunication()
55 AliStorageEventManager *eventManager = AliStorageEventManager::GetEventManagerInstance();
56 storageSockets socket = SERVER_COMMUNICATION_REP;
57 eventManager->CreateSocket(socket);
59 struct serverRequestStruct *request;
63 cout<<"Server waiting for requests"<<endl;
64 request = eventManager->GetServerStruct(socket);
65 cout<<"Server received request"<<endl;
66 switch(request->messageType)
68 case REQUEST_LIST_EVENTS:
70 cout<<"SERVER -- received request for list of events"<<endl;
71 vector<serverListStruct> result = fDatabase->GetList(request->list);
72 cout<<"SERVER -- got list from database"<<endl;
73 eventManager->Send(result,socket);
74 cout<<"SERVER -- list was sent"<<endl;
77 case REQUEST_GET_EVENT:
80 AliESDEvent *event = fDatabase->GetEvent(request->event);
82 eventManager->Send(event,socket);
86 case REQUEST_GET_NEXT_EVENT:
88 cout<<"NEXT EVENT request received"<<endl;
89 AliESDEvent *event = fDatabase->GetNextEvent(request->event);
90 eventManager->Send(event,socket);
94 case REQUEST_GET_PREV_EVENT:
96 AliESDEvent *event = fDatabase->GetPrevEvent(request->event);
97 eventManager->Send(event,socket);
101 case REQUEST_GET_LAST_EVENT:
103 AliESDEvent *event = fDatabase->GetLastEvent();
104 eventManager->Send(event,socket);
108 case REQUEST_GET_FIRST_EVENT:
110 AliESDEvent *event = fDatabase->GetFirstEvent();
111 eventManager->Send(event,socket);
115 case REQUEST_MARK_EVENT:
117 struct eventStruct *markData = &(request->event);
118 eventManager->Send(MarkEvent(*markData),socket);
129 bool AliStorageServerThread::MarkEvent(struct eventStruct event)
131 string pathToFile = fDatabase->GetFilePath(event);
132 TFile *tmpFile = new TFile(pathToFile.c_str(),"read");
135 cout<<"SERVER -- couldn't open temp file"<<endl;
139 tmpFile->cd(Form("run%d",event.runNumber));
141 AliESDEvent *eventToMark = (AliESDEvent*)gDirectory->Get(Form("event%d",event.eventNumber));
144 cout<<"SERVER -- couldn't find such event"<<endl;
145 if(tmpFile){tmpFile->Close();delete tmpFile;}
148 cout<<"SERVER -- Marking event:"<<eventToMark->GetEventNumberInFile()<<endl;
150 TFile *permFile = new TFile(Form("%s/permEvents.root",fStoragePath.c_str()),"update");//open/create perm file
154 cout<<"SERVER -- Couldn't open perm file"<<endl;
155 if(tmpFile){tmpFile->Close();delete tmpFile;}
156 if(eventToMark){delete eventToMark;}
160 //create new directory for this run
161 TDirectory *currentRun;
162 if((currentRun = permFile->mkdir(Form("run%d",event.runNumber))))
164 cout<<"SERVER -- creating new directory for this run"<<endl;
169 cout<<"SERVER -- opening existing directory for this run"<<endl;
170 permFile->cd(Form("run%d",event.runNumber));
173 //try to add record to the database
174 if(!fDatabase->MarkEvent(event))
176 cout<<"SERVER -- could not mark event in the database"<<endl;
177 if(tmpFile){delete tmpFile;}
178 if(eventToMark){delete eventToMark;}
179 if(permFile){delete permFile;}
183 eventToMark->Write(Form("event%d",event.eventNumber));
187 if(tmpFile){delete tmpFile;}
188 if(eventToMark){delete eventToMark;}
189 if(permFile){delete permFile;}
190 // if(currentRun)delete currentRun;//this line crashes if there is no permanent file yet