paramsData->addRequestNode(); $paramsNode = $requestNode->getParamsNode(); //unmarshall time definition $this->unmarshallTimeDefinition($input, 0); //unmarshall download output definition $outputsNode = $requestNode->getOutputsNode(); $downloadNode = $outputsNode->addNewOutput(RequestOutputTypeEnum::DOWNLOAD); //timeformatData : [['Y-m-dTH:i:s', 'YYYY-MM-DDThh:mm:ss'], ['DD Time', 'DD Time'], ['Timestamp', 'Timestamp']], switch ($input->timeformat) { case 'YYYY-MM-DDThh:mm:ss' : $downloadNode->setTimeFormat(RequestOutputDownloadTimeFormatEnum::ISO); break; case 'DD Time' : $downloadNode->setTimeFormat(RequestOutputDownloadTimeFormatEnum::DDTIME); break; case 'Timestamp' : $downloadNode->setTimeFormat(RequestOutputDownloadTimeFormatEnum::TIMESTAMP); break; default : throw new Exception('Time format not implemented.'); } //formatData : [['ASCII', 'ASCII'],['vot', 'VOTable'],['cdf', 'CDF'],['json', 'JSON']], switch ($input->fileformat) { case "ASCII" : $downloadNode->setFileFormat(RequestOutputDownloadFileFormatEnum::ASCII); break; case "vot" : $downloadNode->setFileFormat(RequestOutputDownloadFileFormatEnum::VOTABLE); break; case "cdf" : $downloadNode->setFileFormat(RequestOutputDownloadFileFormatEnum::CDF); break; case "json" : $downloadNode->setFileFormat(RequestOutputDownloadFileFormatEnum::JSON); break; default : throw new Exception('File format not implemented.'); } if ($input->fileprefix != "") $downloadNode->setFileName($input->fileprefix); //add params to output foreach ($input->list as $param) { $paramInfo = $this->paramManager->addExistingParam($param,$this->paramsData); $downloadNode->addParam($paramInfo['id'],$paramInfo['indexes'],$paramInfo['calib_infos']); $paramsNode->addParam($paramInfo['id']); } //filestructureData : [['0','All In One File'], ['1','One File Per Time Interval'], ['2','One File Per Param/Interval']], switch ($input->structure) { case "0" : if (!$input->refparamSampling) { $downloadNode->setSamplingTime($input->sampling); $downloadNode->setStructure(RequestOutputDownloadStructureEnum::ONE_FILE); } else $downloadNode->setStructure(RequestOutputDownloadStructureEnum::ONE_FILE_REFPARAM); break; case "1" : if (!$input->refparamSampling) { $downloadNode->setSamplingTime($input->sampling); $downloadNode->setStructure(RequestOutputDownloadStructureEnum::ONE_FILE_PER_INTERVAL); } else $downloadNode->setStructure(RequestOutputDownloadStructureEnum::ONE_FILE_PER_INTERVAL_REFPARAM); break; case "2" : $downloadNode->setStructure(RequestOutputDownloadStructureEnum::ONE_FILE_PER_PARAMETER_PER_INTERVAL); break; default : throw new Exception('Structure type not implemented.'); } //filecompressData : [['zip', 'zip'], ['tar+gzip', 'tar+gzip']], $extension = ""; switch ($input->compression) { case "zip" : $extension = ".zip"; $downloadNode->addPostProcessing(RequestOutputPostProcessingEnumClass::ZIP); break; case "tar+gzip" : $extension = ".tar.gz"; $downloadNode->addPostProcessing(RequestOutputPostProcessingEnumClass::TAR); $downloadNode->addPostProcessing(RequestOutputPostProcessingEnumClass::GZIP); break; default : throw new Exception('Compression type not implemented.'); } $resultFile = "result_".$this->requestID; $this->paramsData->addWaitingResult(DOWNLOAD_RESULT_FILE_KEY, $resultFile); $postProcessCmd = "mv download_*"; $postProcessCmd .= $extension; $postProcessCmd .= " ".$resultFile.$extension; $this->paramsData->setPostCmd($postProcessCmd); return $this->paramsData; } /* * @brief method to marshall the result of a download request */ protected function marshallResult($data) { return $this->commonMarshallResult($data,DOWNLOAD_RESULT_FILE_KEY); } } ?>