| 1 | //
|
|---|
| 2 | // Generate status.xml for elogbook status display
|
|---|
| 3 | //
|
|---|
| 4 | // Copy executable to /srv/www/htdocs/FACTelog/bin/ and
|
|---|
| 5 | // change owner to 'tomcat'.
|
|---|
| 6 | //
|
|---|
| 7 | // Oliver Grimm, 29/7/2010
|
|---|
| 8 |
|
|---|
| 9 | #include <iostream>
|
|---|
| 10 | #include <fstream>
|
|---|
| 11 |
|
|---|
| 12 | #include "Evidence.h"
|
|---|
| 13 |
|
|---|
| 14 |
|
|---|
| 15 | using namespace std;
|
|---|
| 16 |
|
|---|
| 17 | int main() {
|
|---|
| 18 |
|
|---|
| 19 | string Status1, Status2, Status3, Status4, Status5;
|
|---|
| 20 |
|
|---|
| 21 | // Open file
|
|---|
| 22 | ofstream File("/srv/www/htdocs/FACTelog/jsp/status.xml");
|
|---|
| 23 | if (!File.is_open()) {
|
|---|
| 24 | cerr << "Could not open file for writing" << endl;
|
|---|
| 25 | exit (EXIT_FAILURE);
|
|---|
| 26 | }
|
|---|
| 27 |
|
|---|
| 28 | // Request data from DIM
|
|---|
| 29 | DimCurrentInfo Alarm("Alarm/MasterAlarm", NO_LINK);
|
|---|
| 30 | DimCurrentInfo FBState("Feedback/State", NO_LINK);
|
|---|
| 31 | DimCurrentInfo RunNumber("drsdaq/RunNumber", NO_LINK);
|
|---|
| 32 | DimCurrentInfo RunSize("drsdaq/RunSizeMB", NO_LINK);
|
|---|
| 33 | DimCurrentInfo EventNo("drsdaq/EventNumber", NO_LINK);
|
|---|
| 34 |
|
|---|
| 35 | // Feedback state
|
|---|
| 36 | if (!EvidenceServer::ServiceOK(&FBState)) Status1 = "Feedback state n/a";
|
|---|
| 37 | else Status1 = EvidenceServer::ToString((char *) "I:1;C", FBState.getData(), FBState.getSize()).substr(2);
|
|---|
| 38 |
|
|---|
| 39 | // MasterAlarm level
|
|---|
| 40 | if (!EvidenceServer::ServiceOK(&Alarm)) Status2 = "MasterAlarm n/a";
|
|---|
| 41 | else {
|
|---|
| 42 | switch (Alarm.getInt()) {
|
|---|
| 43 | case 0: Status2 = "OK"; break;
|
|---|
| 44 | case 1: Status2 = "Server WARN"; break;
|
|---|
| 45 | case 2: Status2 = "Server ERROR"; break;
|
|---|
| 46 | case 3: Status2 = "Server FATAL"; break;
|
|---|
| 47 | case 4: Status2 = "Server UNAVAILABLE"; break;
|
|---|
| 48 | default: Status2 = "MasterAlarm ???";
|
|---|
| 49 | }
|
|---|
| 50 | }
|
|---|
| 51 |
|
|---|
| 52 | // Run-related information
|
|---|
| 53 | if (!EvidenceServer::ServiceOK(&RunNumber)) Status3 = "Run #n/a";
|
|---|
| 54 | else Status3 = "Run #" + EvidenceServer::ToString((char *) "I", RunNumber.getData(), RunNumber.getSize());
|
|---|
| 55 |
|
|---|
| 56 | if (!EvidenceServer::ServiceOK(&RunSize)) Status4 = "Size n/a";
|
|---|
| 57 | else Status4 = "Size " + EvidenceServer::ToString((char *) "F", RunSize.getData(), RunSize.getSize()) + " MB";
|
|---|
| 58 |
|
|---|
| 59 | if (!EvidenceServer::ServiceOK(&RunSize)) Status5 = "Event #n/a";
|
|---|
| 60 | else Status5 = "Event #" + EvidenceServer::ToString((char *) "I", EventNo.getData(), EventNo.getSize());
|
|---|
| 61 |
|
|---|
| 62 | // Write file
|
|---|
| 63 | File << "<status_info>" << endl;
|
|---|
| 64 | File << "<status_val1>" << Status1 << "</status_val1>" << endl;
|
|---|
| 65 | File << "<status_val2>" << Status2 << "</status_val2>" << endl;
|
|---|
| 66 | File << "<status_val3>" << Status3 << "</status_val3>" << endl;
|
|---|
| 67 | File << "<status_val4>" << Status4 << "</status_val4>" << endl;
|
|---|
| 68 | File << "<status_val5>" << Status5 << "</status_val5>" << endl;
|
|---|
| 69 | File << "<status_val6>" << " " << "</status_val6>" << endl;
|
|---|
| 70 | File << "</status_info>" << endl;
|
|---|
| 71 |
|
|---|
| 72 | // Close file
|
|---|
| 73 | File.close();
|
|---|
| 74 | }
|
|---|