/********************************************//** * @file slsReceiver_funcs.h * @short interface between receiver and client ***********************************************/ #include "slsReceiver_funcs.h" #include "slsReceiverFunctionList.h" #include "svnInfoReceiver.h" #include #include #include #include #include using namespace std; int slsReceiverFuncs::file_des(-1); int slsReceiverFuncs::socketDescriptor(-1); slsReceiverFuncs::slsReceiverFuncs(MySocketTCP *&mySocket,string const fname,int &success, bool shortfname): socket(mySocket), ret(OK), lockStatus(0){ int port_no = DEFAULT_PORTNO+2; ifstream infile; string sLine,sargname; int iline = 0; if(!fname.empty()){ #ifdef VERBOSE std::cout<< "config file name "<< fname << std::endl; #endif infile.open(fname.c_str(), ios_base::in); if (infile.is_open()) { while(infile.good()){ getline(infile,sLine); iline++; #ifdef VERBOSE cout << str << endl; #endif if(sLine.find('#')!=string::npos){ #ifdef VERBOSE cout << "Line is a comment " << endl; #endif continue; }else if(sLine.length()<2){ #ifdef VERBOSE cout << "Empty line " << endl; #endif continue; }else{ istringstream sstr(sLine); //parameter name if(sstr.good()) sstr >> sargname; //value if(sargname=="dataport"){ if(sstr.good()) { sstr >> sargname; sscanf(sargname.c_str(),"%d",&port_no); } } } } infile.close(); }else { cout << "Error opening configuration file " << fname << endl; success = FAIL; } //#ifdef VERBOSE cout << "Read configuration file of " << iline << " lines" << endl; //#endif } if(success == OK){ //create socket MySocketTCP* mySocket = new MySocketTCP(port_no); if (mySocket->getErrorStatus()) success = FAIL; else{ delete socket; socket = mySocket; //initialize variables strcpy(socket->lastClientIP,"none"); strcpy(socket->thisClientIP,"none1"); strcpy(mess,"dummy message"); function_table(); slsReceiverList = new slsReceiverFunctionList(shortfname); file_des=socket->getFileDes(); socketDescriptor=socket->getsocketDescriptor(); success = OK; } } } int slsReceiverFuncs::function_table(){ for (int i=0;iReceiveDataOnly(&fnum,sizeof(fnum)); if (n <= 0) { #ifdef VERBOSE cout << "ERROR reading from socket " << n << ", " << fnum << endl; #endif return FAIL; } #ifdef VERBOSE else cout << "size of data received " << n <SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(mess,sizeof(mess)); return GOODBYE; } void slsReceiverFuncs::closeFile(int p){ char *buf; char buffer[1]; if(slsReceiverFunctionList::listening_thread_running) fclose(slsReceiverFunctionList::sfilefd); close(file_des); //shutdown(socketDescriptor,SHUT_RDWR); close(socketDescriptor); } int slsReceiverFuncs::set_file_name() { ret=OK; char retval[MAX_STR_LENGTH]=""; char fName[MAX_STR_LENGTH]; strcpy(mess,"Could not set file name"); // receive arguments if(socket->ReceiveDataOnly(fName,MAX_STR_LENGTH) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else strcpy(retval,slsReceiverList->setFileName(fName)); } #ifdef VERBOSE if(ret!=FAIL) cout << "file name:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } int slsReceiverFuncs::set_file_dir() { ret=OK; char retval[MAX_STR_LENGTH]=""; char fPath[MAX_STR_LENGTH]; strcpy(mess,"Could not set file path\n"); // receive arguments if(socket->ReceiveDataOnly(fPath,MAX_STR_LENGTH) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if((strlen(fPath))&&(slsReceiverList->getStatus()==RUNNING)){ strcpy(mess,"Can not set file path while receiver running\n"); ret = FAIL; } else{ strcpy(retval,slsReceiverList->setFilePath(fPath)); // if file path doesnt exist if(strlen(fPath)) if (strcmp(retval,fPath)){ strcpy(mess,"receiver file path does not exist\n"); ret=FAIL; } } } #ifdef VERBOSE if(ret!=FAIL) cout << "file path:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } int slsReceiverFuncs::set_file_index() { ret=OK; int retval=-1; int index; strcpy(mess,"Could not set file index\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){//necessary??? sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else retval=slsReceiverList->setFileIndex(index); } #ifdef VERBOSE if(ret!=FAIL) cout << "file index:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::setup_udp(){ ret=OK; strcpy(mess,"could not set up udp connection"); char retval[MAX_STR_LENGTH]=""; char args[2][MAX_STR_LENGTH]; string temp; int udpport; char eth[MAX_STR_LENGTH]; // receive arguments if(socket->ReceiveDataOnly(args,sizeof(args)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){//necessary??? sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(slsReceiverList->getStatus()==RUNNING){ ret = FAIL; strcpy(mess,"cannot set up udp when receiver is running\n"); } else{ //set up udp port sscanf(args[1],"%d",&udpport); slsReceiverList->setUDPPortNo(udpport); //setup udpip //get ethernet interface or IP to listen to temp = genericSocket::ipToName(args[0]); if(temp=="none"){ ret = FAIL; strcpy(mess, "failed to get ethernet interface or IP to listen to\n"); } else{ strcpy(eth,temp.c_str()); cout<<"eth:"<setEthernetInterface(eth); //get mac address from ethernet interface temp = genericSocket::nameToMac(eth); if(temp=="00:00:00:00:00:00"){ ret = FAIL; strcpy(mess,"failed to get mac adddress to listen to\n"); } else{ strcpy(retval,temp.c_str()); cout<<"mac:"<differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } int slsReceiverFuncs::start_receiver(){ ret=OK; strcpy(mess,"Could not start receiver\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(!strlen(slsReceiverList->setFilePath(""))){ strcpy(mess,"receiver not set up. set receiver ip again.\n"); ret = FAIL; } else if(slsReceiverList->getStatus()!=RUNNING) ret=slsReceiverList->startReceiver(); #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); //return ok/fail return ret; } int slsReceiverFuncs::stop_receiver(){ ret=OK; strcpy(mess,"Could not stop receiver\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(slsReceiverList->getStatus()!=IDLE) ret=slsReceiverList->stopReceiver(); #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); //return ok/fail return ret; } int slsReceiverFuncs::get_status(){ ret=OK; enum runStatus retval; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST retval=slsReceiverList->getStatus(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::get_frames_caught(){ ret=OK; int retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST retval=slsReceiverList->getTotalFramesCaught(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::get_frame_index(){ ret=OK; int retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST retval=slsReceiverList->getAcquisitionIndex(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::reset_frames_caught(){ ret=OK; int retval=-1; int index=-1; strcpy(mess,"Could not reset frames caught\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0) {; sprintf(mess,"Error reading from socket\n"); ret=FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else retval=slsReceiverList->resetTotalFramesCaught(index); } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::read_frame(){ ret=OK; char fName[MAX_STR_LENGTH]; int arg = -1; int nel = BUFFER_SIZE/(sizeof(int)); int onebuffersize = BUFFER_SIZE/2; int onedatasize = DATABYTES/2; char* raw = new char[BUFFER_SIZE]; int* origVal = new int[nel]; int* retval = new int[nel]; int index=-1,index2=-1; int startIndex=-1; int count=0; strcpy(mess,"Could not read frame\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST //wait till you get first frame 1. to get index(from startindex 2. filename corresponds to buffer value ret=FAIL; strcpy(mess,"did not start index\n"); for(int i=0;i<10;i++){ startIndex=slsReceiverList->getStartFrameIndex(); if(startIndex!=-1){ ret=OK; break; }else usleep(1000000); } //got atleast first frame, read buffer if(ret==OK){ while(count<20){ //get frame raw=slsReceiverList->readFrame(fName); index=(int)(*(int*)raw); index2= (int)(*((int*)((char*)(raw+onebuffersize)))); memcpy(origVal,raw,BUFFER_SIZE); raw=NULL; //cout<<"funcs\tindex:"<differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL){ cout << "mess:" << mess << endl; socket->SendDataOnly(mess,sizeof(mess)); } else{ socket->SendDataOnly(fName,MAX_STR_LENGTH); socket->SendDataOnly(&arg,sizeof(arg)); socket->SendDataOnly(retval,DATABYTES); } //return ok/fail return ret; } int slsReceiverFuncs::enable_file_write(){ ret=OK; int retval=-1; int enable; strcpy(mess,"Could not set/get enable file write\n"); // receive arguments if(socket->ReceiveDataOnly(&enable,sizeof(enable)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){//necessary??? sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ retval=slsReceiverList->setEnableFileWrite(enable); if((enable!=-1)&&(enable!=retval)) ret=FAIL; } } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::get_version(){ ret=OK; int64_t retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_FUNCTION_LIST retval= SVNREV; retval= (retval <<32) | SVNDATE; #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverFuncs::lock_receiver() { ret=OK; int lock; // receive arguments if(socket->ReceiveDataOnly(&lock,sizeof(lock)) < 0 ){ sprintf(mess,"Error reading from socket\n"); cout << "Error reading from socket (lock)" << endl; ret=FAIL; } // execute action if the arguments correctly arrived if(ret==OK){ if (lock>=0) { if (lockStatus==0 || strcmp(socket->lastClientIP,socket->thisClientIP)==0 || strcmp(socket->lastClientIP,"none")==0) { lockStatus=lock; strcpy(socket->lastClientIP,socket->thisClientIP); } else { ret=FAIL; sprintf(mess,"Receiver already locked by %s\n", socket->lastClientIP); } } } if (socket->differentClients && ret==OK) ret=FORCE_UPDATE; // send answer socket->SendDataOnly(&ret,sizeof(ret)); if (ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); else socket->SendDataOnly(&lockStatus,sizeof(lockStatus)); //return ok/fail return ret; } int slsReceiverFuncs::set_port() { ret=OK; MySocketTCP* mySocket=NULL; int sd=-1; enum portType p_type; /** data? control? stop? Unused! */ int p_number; /** new port number */ // receive arguments if(socket->ReceiveDataOnly(&p_type,sizeof(p_type)) < 0 ){ strcpy(mess,"Error reading from socket\n"); cout << mess << endl; ret=FAIL; } if(socket->ReceiveDataOnly(&p_number,sizeof(p_number)) < 0 ){ strcpy(mess,"Error reading from socket\n"); cout << mess << endl; ret=FAIL; } // execute action if the arguments correctly arrived if (ret==OK) { if (socket->differentClients==1 && lockStatus==1 ) { ret=FAIL; sprintf(mess,"Detector locked by %s\n",socket->lastClientIP); } else { if (p_number<1024) { sprintf(mess,"Too low port number %d\n", p_number); cout << mess << endl; ret=FAIL; } cout << "set port " << p_type << " to " << p_number <getErrorStatus(); if (!sd){ ret=OK; if (mySocket->differentClients) ret=FORCE_UPDATE; } else { ret=FAIL; sprintf(mess,"Could not bind port %d\n", p_number); cout << mess << endl; if (sd==-10) { sprintf(mess,"Port %d already set\n", p_number); cout << mess << endl; } } } } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if (ret==FAIL) { socket->SendDataOnly(mess,sizeof(mess)); } else { socket->SendDataOnly(&p_number,sizeof(p_number)); if(sd>=0){ socket->Disconnect(); delete socket; socket = mySocket; file_des=socket->getFileDes(); } } //return ok/fail return ret; } int slsReceiverFuncs::get_last_client_ip() { ret=OK; if (socket->differentClients ) ret=FORCE_UPDATE; socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(socket->lastClientIP,sizeof(socket->lastClientIP)); return ret; } int slsReceiverFuncs::send_update() { ret=OK; int ind; char path[MAX_STR_LENGTH]; socket->SendDataOnly(socket->lastClientIP,sizeof(socket->lastClientIP)); //index #ifdef SLS_RECEIVER_FUNCTION_LIST ind=slsReceiverList->getFileIndex(); #endif socket->SendDataOnly(&ind,sizeof(ind)); //filepath #ifdef SLS_RECEIVER_FUNCTION_LIST strcpy(path,slsReceiverList->getFilePath()); #endif socket->SendDataOnly(path,MAX_STR_LENGTH); //filename #ifdef SLS_RECEIVER_FUNCTION_LIST strcpy(path,slsReceiverList->getFileName()); #endif socket->SendDataOnly(path,MAX_STR_LENGTH); if (lockStatus==0) { strcpy(socket->lastClientIP,socket->thisClientIP); } return ret; } int slsReceiverFuncs::update_client() { ret=OK; socket->SendDataOnly(&ret,sizeof(ret)); return send_update(); } int slsReceiverFuncs::exit_server() { ret=GOODBYE; socket->SendDataOnly(&ret,sizeof(ret)); strcpy(mess,"closing server"); socket->SendDataOnly(mess,sizeof(mess)); cout << mess << endl; return ret; } int slsReceiverFuncs::exec_command() { ret = OK; char cmd[MAX_STR_LENGTH]; char answer[MAX_STR_LENGTH]; int sysret=0; // receive arguments if(socket->ReceiveDataOnly(cmd,MAX_STR_LENGTH) < 0 ){ sprintf(mess,"Error reading from socket\n"); ret=FAIL; } // execute action if the arguments correctly arrived if (ret==OK) { #ifdef VERBOSE cout << "executing command " << cmd << endl; #endif if (lockStatus==0 || socket->differentClients==0) sysret=system(cmd); //should be replaced by popen if (sysret==0) { strcpy(answer,"Succeeded\n"); if (lockStatus==1 && socket->differentClients==1) sprintf(answer,"Detector locked by %s\n", socket->lastClientIP); } else { strcpy(answer,"Failed\n"); ret=FAIL; } } else strcpy(answer,"Could not receive the command\n"); // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(socket->SendDataOnly(answer,MAX_STR_LENGTH) < 0){ strcpy(mess,"Error writing to socket"); ret=FAIL; } //return ok/fail return ret; }