*/
public $soapMethods = array("calculateDataPointValue", "calculateDataPointValue_Spacecraft");
//
//
public $additionalArgs = array("spase://IMPEX/NumericalOutput/LESIA/MAG/Jupiter/sc" => array("StartTime" => "dateTime", "StopTime" => "dateTime", "Sampling"=> "float" ),
"spase://IMPEX/NumericalOutput/LESIA/MAG/Jupiter/xyz" => array("StartTime" => "dateTime"));
private $calculateDataPointValue_Args = null;
private $spacecraft = array("Cassini", "Galileo");
private $internalModel = array("O6", "VIP4", "VIT4", "VIPAL");
private $currentSheet = array("None", "Connerney", "Khurana");
private $coordinateSystem = array("JSO", "JSM", "JSS", "PlanetaryCartesian","PlanetarySpherical","Planetarographic");
/*
*/
//Extraparam: OutputFormat => netCDF, VOTable
public $outputFormat = "VOTable";
private function initArgs()
{
if ($this->calculateDataPointValue_Args) return;
$this->calculateDataPointValue_Args = array();
$this->calculateDataPointValue_Args["InternalModel"] = $this->internalModel;
$this->calculateDataPointValue_Args["CurrentSheet"] = $this->currentSheet;
$this->calculateDataPointValue_Args["CoordinateSystem"] = $this->coordinateSystem;
}
protected function createMissionNodes()
{
$missionNodes = array();
foreach ($this->tree->SimulationModel as $sm)
{
$ResourceID = trim($sm->ResourceID);
$simulationModel = $this->domAmda->createElement('simulationModel');
$simReg = $sm->SimulatedRegion;
$simulationModel->setAttribute('xml:id', $sm->ResourceID);
$simulationModel->setAttribute('name', $sm->ResourceHeader->ResourceName." : ".$simReg);
$simulationModel->setAttribute('desc', $sm->ResourceHeader->Description.'
ReleaseDate: '.$sm->ResourceHeader->ReleaseDate);
if (file_exists(DATAPATH.'rank.json'))
$cmpArr = json_decode(file_get_contents(DATAPATH.'rank.json'), true);
else
$cmpArr = null;
$index = $cmpArr["$simReg"];
if ($index)
$simulationModel->setAttribute('rank',$index);
else
$simulationModel->setAttribute('rank', 999);
$simulationModel->setAttribute('att', "simu/simu$simReg");
// $this->setModelHelp($simulationModel,"");
$this->addSimulatedRegionToTargetsFile($simReg, "JSM"); //TODO check this
$datasetNodes = $this->createDatasetNodes($simReg);
foreach ($datasetNodes as $ds)
{
$parameterNodes = $this->createParameterNodes($sm->OutputParameters->Parameter, $ds->getAttribute('xml:id'));
foreach ($parameterNodes as $node )
$ds->appendChild($node);
$simulationModel->appendChild($ds);
}
$missionNodes[] = $simulationModel;
}
return $missionNodes;
}
protected function createDatasetNodes()
{
$datasetNodes = array();
foreach ($this->soapMethods as $soapMethod)
{
$datasetNode = $this->domAmda->createElement('dataset');
$datasetNode->setAttribute('name', $soapMethod);
if ($soapMethod == "calculateDataPointValue_Spacecraft")
$datasetNode->setAttribute('xml:id', $this->prefix."/sc");
else
$datasetNode->setAttribute('xml:id', $this->prefix."/xyz");
$datasetNode->setAttribute('globalStart', 'depending on mission');
$datasetNodes[] = $datasetNode;
}
return $datasetNodes;
}
protected function createParameterNodes($params, $dsid)
{
$paramNodes = array();
foreach ($params as $param)
{
$paramNode = $this->domAmda->createElement('parameter');
$id = $this->param2dd($dsid."/".$param->ParameterKey);
$paramNode->setAttribute('xml:id',$id);
$paramNode->setAttribute('name', $param->ParameterKey);
$paramNode->setAttribute('desc', 'Units: '.$param->Units);
$paramNode->setAttribute('shortName',$param->ParameterKey);
$paramNode->setAttribute('needsArgs', $this->needsArgs);
if ($this->hasComponents($param))
{
if (strpos(trim($param->ParameterKey), ',') === false)
$comps = explode(' ',trim($param->ParameterKey));
else
$comps = explode(',',trim($param->ParameterKey));
$paramNode->setAttribute('size', count($comps));
foreach ($comps as $comp)
{
$compNode = $this->domAmda->createElement('component');
// $compNode->setAttribute('xml:id', $id."_".$comp);
$compNode->setAttribute('xml:id',$this->param2dd($dsid."_".$comp));
$compNode->setAttribute('name', $comp);
$compNode->setAttribute('needsArgs', $this->needsArgs);
$compNode->setAttribute('shortName',$comp);
$paramNode->appendChild($compNode);
}
}
$paramNodes[] = $paramNode;
}
return $paramNodes;
}
protected function createSpecialArgs($dom)
{
$this->initArgs();
$nodes = array();
foreach ($this->calculateDataPointValue_Args as $key => $values)
{
$node = $dom->createElement('argument');
$node->setAttribute('key', $key);
$node->setAttribute('name', $key);
$node->setAttribute('type', 'list');
foreach ($values as $value)
{
$item = $dom->createElement('item');
$item->setAttribute('name',$value);
$item->setAttribute('key', $value);
$node->appendChild($item);
}
$node->setAttribute('default', $values[0]);
$nodes[] = $node;
}
$node = $dom->createElement('argument');
return $nodes;
}
protected function createSpecialScArgs($dom)
{
$node = $dom->createElement('argument');
$node->setAttribute('key', 'Spacecraft_name');
$node->setAttribute('name', $key);
$node->setAttribute('type', 'list');
foreach ($this->spacecraft as $value)
{
$item = $dom->createElement('item');
$item->setAttribute('name',$value);
$item->setAttribute('key', $value);
$node->appendChild($item);
}
$node->setAttribute('default', $this->spacecraft[0]);
return $node;
}
public function makeArgumentsList()
{
if (!file_exists(SimuTargetsXml))
exit('NOT YET!'.PHP_EOL);
if (file_exists($this->templateFile))
unlink($this->templateFile);
$TemplatesXml = new DomDocument("1.0");
$TemplatesXml->formatOutput = TRUE;
$TemplatesXml->preserveWhiteSpace = FALSE;
$rootNode = $TemplatesXml->createElement('paramTemplateList');
$TemplatesXml->appendChild($rootNode);
$TargetsXml = new DomDocument("1.0");
$TargetsXml->load(SimuTargetsXml);
$targets = $TargetsXml->getElementsByTagName('Target');
foreach ($targets as $target)
{
if ($target->hasAttribute($this->baseID))
{
echo $target->getAttribute('xml:id').PHP_EOL;
foreach ($this->soapMethods as $soapMethod)
{
$paramNode = $TemplatesXml->createElement('paramTemplate');
$paramNode->setAttribute('fileName','##internalField####currentSheet##');
$argsNode = $TemplatesXml->createElement('arguments');
$paramNode->appendChild($argsNode);
$specialNodes = $this->createSpecialArgs($TemplatesXml);
foreach ($specialNodes as $specialNode)
$argsNode->appendChild($specialNode);
if ($soapMethod == "calculateDataPointValue")
{
$missionGrps = json_decode(file_get_contents(RemoteData.$target->nodeValue.".json"), true);
$node = $TemplatesXml->createElement('argument');
$node->setAttribute('key', 'url_XYZ');
$node->setAttribute('name', 'Mission Name');
$node->setAttribute('type', 'list');
foreach ($missionGrps as $grp => $missions)
{
foreach ( $missions as $mission => $datasets)
{
echo 'MISSION: '.$mission.PHP_EOL;
foreach ($datasets as $dataset => $parameters)
{
echo " ".$dataset.PHP_EOL;
foreach ($parameters as $param => $value)
{
$item = $TemplatesXml->createElement('item');
$item->setAttribute('name', $mission);
$item->setAttribute('key', $value);
$node->appendChild($item);
}
}
}
}
//TODO select default s/c for each target
$node->setAttribute('default', $value);
$argsNode->appendChild($node);
$paramNode->setAttribute('paramId', $this->prefix."/xyz");
}
else // calculateDataPointValue_Spacecraft
{
$scNode = $this->createSpecialScArgs($TemplatesXml);
$argsNode->appendChild($scNode);
$paramNode->setAttribute('paramId', $this->prefix."/sc");
}
$rootNode->appendChild($paramNode);
}
}
}
$TemplatesXml->save(RemoteData.$this->baseID."/".$this->templateFile);
}
public function getData($params, $isSpectra = false)
{
// $r = print_r($params,true);
// error_log($r,3,'/home/budnik/LOG');
if (strpos('xyz', $params['ResourceID']) > 0)
$realSoapMethod = $this->soapMethods[0];
else
$realSoapMethod = $this->soapMethods[1];
$params['ResourceID'] = $this->resourceID;
try
{
$client = new SoapClient($this->url."/".$this->WSDL,
array(
'wsdl_cache' => 0,
'trace' => 1,
'soap_version'=>SOAP_1_2
));
}
catch (SoapFault $exception)
{
throw new Exception($exception->getMessage()." ".$exception->getTraceAsString());
}
$realSoapMethod = $this->soapMethods[0];
try
{
$file = $client->__soapCall($realSoapMethod, array($params));
}
catch (SoapFault $exception)
{
throw new Exception($exception->getMessage()." ".$exception->getTraceAsString());
}
return $file;
}
}
?>