Blame view

php/classes/AmdaAction.php 37 KB
16035364   Benjamin Renard   First commit
1
2
3
<?php
/**
 * @class AmdaAction
aa94fd24   elena   Merge with last svn
4
 * @version $Id: AmdaAction.php 2976 2015-07-01 15:05:40Z benjamin $
9e3cbd95   Elena.Budnik   merge AMDA_IHM AM...
5
 * @brief
16035364   Benjamin Renard   First commit
6
 */
10200969   Roipoussiere   Remove whitespace...
7
class AmdaAction
735c653b   Elena.Budnik   rank at observato...
8
{
10200969   Roipoussiere   Remove whitespace...
9
	private $xmlFiles  = array('localParam' => 'LocalParams.xml', 'remoteParam' => 'RemoteParams.xml',
735c653b   Elena.Budnik   rank at observato...
10
										'remoteSimuParam' => 'RemoteParams.xml', 'derivedParam' => 'WsParams.xml', 'myDataParam' => 'WsParams.xml',
10200969   Roipoussiere   Remove whitespace...
11
12
										'timeTable' => 'Tt.xml', 'catalog' => 'Tt.xml', 'alias' => 'Alias.xml',
										'myData' => 'Files.xml',
735c653b   Elena.Budnik   rank at observato...
13
14
15
16
17
										'request' => 'Request.xml', 'condition' => 'Request.xml',
										'bkgWorks' => 'jobs.xml');

	private $user, $amdaStat;

10200969   Roipoussiere   Remove whitespace...
18
19
	public function __construct()
	{
735c653b   Elena.Budnik   rank at observato...
20
21
22
23
24
		$dd = new UserMgr();
		$this->user = $dd->user;
		if (!defined('NEWKERNEL_DEBUG') || !NEWKERNEL_DEBUG)
					$this->amdaStat = new AmdaStats($dd->user);
	}
16035364   Benjamin Renard   First commit
25

10200969   Roipoussiere   Remove whitespace...
26
	private function getUrlDirs($url)
735c653b   Elena.Budnik   rank at observato...
27
28
29
	{
		//TODO replace by ftp php class methods: ftp_nlist() etc
		require_once "simple_html_dom.php";
10200969   Roipoussiere   Remove whitespace...
30
31

		$url = html_entity_decode($url);
735c653b   Elena.Budnik   rank at observato...
32
		$trimmed_url = trim($url);
10200969   Roipoussiere   Remove whitespace...
33
		if (strrpos($trimmed_url, "/") == strlen($trimmed_url) - 1)
735c653b   Elena.Budnik   rank at observato...
34
		{
10200969   Roipoussiere   Remove whitespace...
35
			if (file_exists("temp.html")) unlink("temp.html");
735c653b   Elena.Budnik   rank at observato...
36
			exec("wget -O temp.html ".$url);
10200969   Roipoussiere   Remove whitespace...
37

735c653b   Elena.Budnik   rank at observato...
38
39
			$html = file_get_html('temp.html');
			$dirs = $html->find('a[href]');
10200969   Roipoussiere   Remove whitespace...
40
			foreach ($dirs as $dir)
735c653b   Elena.Budnik   rank at observato...
41
			{
6acb8d2a   Elena.Budnik   checkRequest in R...
42
43
				$name =  $dir->innertext; //$dir->href;
				$isLeaf = strrpos($name, "/") !== strlen($name) - 1;
10200969   Roipoussiere   Remove whitespace...
44
				$childrenToReturn[] = array('text' => $name, 'id' => $trimmed_url.$name, 'nodeType' => 'url', 'leaf' => $isLeaf);
735c653b   Elena.Budnik   rank at observato...
45
			}
10200969   Roipoussiere   Remove whitespace...
46

735c653b   Elena.Budnik   rank at observato...
47
		}
10200969   Roipoussiere   Remove whitespace...
48
49
50

		return $childrenToReturn;

735c653b   Elena.Budnik   rank at observato...
51
	}
10200969   Roipoussiere   Remove whitespace...
52

16035364   Benjamin Renard   First commit
53
54
/*****************************************************************
*                           PUBLIC FUNCTIONS
10200969   Roipoussiere   Remove whitespace...
55
56
*****************************************************************/

735c653b   Elena.Budnik   rank at observato...
57
58
59
60
	/*
	*   $obj = { id: node.id,  nodeType: node.nodeType }
	*/
	public function getTree($obj) {
16035364   Benjamin Renard   First commit
61

735c653b   Elena.Budnik   rank at observato...
62
		$node = $obj->node;
10200969   Roipoussiere   Remove whitespace...
63

735c653b   Elena.Budnik   rank at observato...
64
		$nodeType = $obj->nodeType;
a0f13ed1   Elena.Budnik   small format + ti...
65
		
735c653b   Elena.Budnik   rank at observato...
66
67
		$remoteBase = false;
		$isRemoteDataSet = false;
16035364   Benjamin Renard   First commit
68

10200969   Roipoussiere   Remove whitespace...
69
		if ($nodeType == 'url')
735c653b   Elena.Budnik   rank at observato...
70
		{
10200969   Roipoussiere   Remove whitespace...
71
			$url = $node == 'root' ? $obj->baseId : $node;
735c653b   Elena.Budnik   rank at observato...
72
73
			return  $this->getUrlDirs($url);
		}
16035364   Benjamin Renard   First commit
74

e57cb025   Benjamin Renard   Fix most of error...
75
		if (isset($obj->baseId)) $remoteBase = true;
16035364   Benjamin Renard   First commit
76

735c653b   Elena.Budnik   rank at observato...
77
		if ($node == 'root' && $remoteBase)  $node = $obj->baseId;
16035364   Benjamin Renard   First commit
78

10200969   Roipoussiere   Remove whitespace...
79
80
		if ($node == 'root' && !$remoteBase)
		{
e57cb025   Benjamin Renard   Fix most of error...
81
82
83
84
85
86
87
88
89
90
91
92
			if (file_exists(DATAPATH.$nodeType.'.json')) {
				$json_o = json_decode(file_get_contents(DATAPATH.$nodeType.'.json'));
				if (empty($json_o)) {
					$childrenToReturn = array();
				}
				else {
					$childrenToReturn = $json_o->nodes;
				}
			}
			else {
				$childrenToReturn = array();
			}
10200969   Roipoussiere   Remove whitespace...
93
94
		}
		else
735c653b   Elena.Budnik   rank at observato...
95
96
97
		{
			$Dom = new DomDocument("1.0");

10200969   Roipoussiere   Remove whitespace...
98
			switch ($nodeType)
735c653b   Elena.Budnik   rank at observato...
99
100
101
102
103
			{
				case 'sharedtimeTable':
				case 'sharedcatalog':
					$xmlName = SHAREDPATH.'/SharedObjectTree.xml';
					break;
10200969   Roipoussiere   Remove whitespace...
104
				case 'bkgWorks':
735c653b   Elena.Budnik   rank at observato...
105
106
107
					$xmlName = USERJOBDIR.$this->xmlFiles[$nodeType];
					break;
				case 'source':
10200969   Roipoussiere   Remove whitespace...
108
109
110
111
					$xmlName = DATAPATH.'RemoteData/'.$obj->baseId.'/base.xml';
					break;
				case 'destination':
					$xmlName = USERWSDIR.'RemoteParams.xml';
735c653b   Elena.Budnik   rank at observato...
112
					break;
735c653b   Elena.Budnik   rank at observato...
113
114
115
				default:
					$xmlName = USERWSDIR.$this->xmlFiles[$nodeType];
			}
16035364   Benjamin Renard   First commit
116

a0f13ed1   Elena.Budnik   small format + ti...
117
			if ($remoteBase){
735c653b   Elena.Budnik   rank at observato...
118
				$nodeType = 'remoteParam';
10200969   Roipoussiere   Remove whitespace...
119
120
			}

e57cb025   Benjamin Renard   Fix most of error...
121
			@$Dom->load($xmlName);
10200969   Roipoussiere   Remove whitespace...
122

a0f13ed1   Elena.Budnik   small format + ti...
123
			if ($node == "myRemoteSimuData-treeRootNode") $node = "myRemoteData-treeRootNode";
10200969   Roipoussiere   Remove whitespace...
124

735c653b   Elena.Budnik   rank at observato...
125
			$nodeToOpen = $Dom->getElementById($node);
e57cb025   Benjamin Renard   Fix most of error...
126
			$children = empty($nodeToOpen->childNodes) ? array() : $nodeToOpen->childNodes;
16035364   Benjamin Renard   First commit
127

10200969   Roipoussiere   Remove whitespace...
128
129
			foreach ($children as $child)
				if ($child->nodeType == XML_ELEMENT_NODE)
735c653b   Elena.Budnik   rank at observato...
130
131
				{
					$isLeaf = true;
10200969   Roipoussiere   Remove whitespace...
132

735c653b   Elena.Budnik   rank at observato...
133
					if ($child->hasChildNodes())
10200969   Roipoussiere   Remove whitespace...
134
135
						foreach ($child->childNodes as $grandChild)
							if ($grandChild -> nodeType == XML_ELEMENT_NODE)
735c653b   Elena.Budnik   rank at observato...
136
137
138
139
140
141
							{
									$isLeaf = false;
									break;
							}
					if ($child->tagName == 'folder')  $isLeaf = false;

10200969   Roipoussiere   Remove whitespace...
142
143
					//TODO MAKE PROPERLY  as function of nodetype !!!!
					$info = '';
735c653b   Elena.Budnik   rank at observato...
144
					$id =  $child->getAttribute('xml:id');
10200969   Roipoussiere   Remove whitespace...
145
					$name = $child->getAttribute('name');
735c653b   Elena.Budnik   rank at observato...
146
147
148
149
150
151
152
153
154
					$help = $child->getAttribute('att');
					if ($child->hasAttribute('dataStart')) $dataStart = $child->getAttribute('dataStart');
					if ($child->hasAttribute('dataStop')) $dataStop = $child->getAttribute('dataStop');

					$specialNode = false;
					$isParameter = false;
					$isAddable =  false;
					$isSimulation = false;
					$rank = null;
e57cb025   Benjamin Renard   Fix most of error...
155
					$skip = FALSE;
735c653b   Elena.Budnik   rank at observato...
156

10200969   Roipoussiere   Remove whitespace...
157
					switch ($nodeType)
735c653b   Elena.Budnik   rank at observato...
158
					{
10200969   Roipoussiere   Remove whitespace...
159
						case 'bkgWorks':
735c653b   Elena.Budnik   rank at observato...
160
161
							$specialNode = true;
							$status = $child->getAttribute('status');
10200969   Roipoussiere   Remove whitespace...
162
							//     if ($status == 'done') continue;
735c653b   Elena.Budnik   rank at observato...
163
							$childrenToReturn[] = array('text' => $name, 'id' => $id,'nodeType' => $nodeType, 'leaf' => $isLeaf,
10200969   Roipoussiere   Remove whitespace...
164
									'pid' => $child->getAttribute('pid'), 'status' => $status,
735c653b   Elena.Budnik   rank at observato...
165
166
167
168
169
									'jobType' => $child->getAttribute('jobType'), 'info' => $child->getAttribute('info'));
						break;

						case 'condition':
							$objectMgr = new RequestMgr();
10200969   Roipoussiere   Remove whitespace...
170
171
							$info = $objectMgr->getObject($id)->expression;
						break;
735c653b   Elena.Budnik   rank at observato...
172

10200969   Roipoussiere   Remove whitespace...
173
						case 'request':
735c653b   Elena.Budnik   rank at observato...
174
						$objectMgr = new RequestMgr();
10200969   Roipoussiere   Remove whitespace...
175
176
177
178
						$objplot = $objectMgr->getObject($id);
						for ($i=0; $i < count($objplot->children); $i++)
						{
							for ($j=0; $j < count($objplot->children[$i]->children); $j++)
735c653b   Elena.Budnik   rank at observato...
179
180
181
182
							{
								$info = $info.' '.$objplot->children[$i]->children[$j]->name;
							}
						}
10200969   Roipoussiere   Remove whitespace...
183
						break;
735c653b   Elena.Budnik   rank at observato...
184

10200969   Roipoussiere   Remove whitespace...
185
						case 'alias':
735c653b   Elena.Budnik   rank at observato...
186
187
							$info = $id;
							$id = 'alias_'.$id;
10200969   Roipoussiere   Remove whitespace...
188
							if ($isLeaf) $isParameter = true;
735c653b   Elena.Budnik   rank at observato...
189
190
191
						break;

						case 'timeTable':
10200969   Roipoussiere   Remove whitespace...
192
						case 'catalog':
735c653b   Elena.Budnik   rank at observato...
193
194
							if ($isLeaf) $info = $child->getAttribute('intervals').' intervals';
						break;
10200969   Roipoussiere   Remove whitespace...
195

735c653b   Elena.Budnik   rank at observato...
196
197
						case 'sharedtimeTable':
						case 'sharedcatalog':
10200969   Roipoussiere   Remove whitespace...
198
							if ($isLeaf)
735c653b   Elena.Budnik   rank at observato...
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
							{
								$info = '<b>Nb intervals:</b> '.$child->getAttribute('nbIntervals').'<br/>';
								$info .= '<b>Shared by:</b> '.$child->getAttribute('sharedBy').' ('.$child->getAttribute('sharedDate').')<br/>';
								$info .= '<b>Description:</b> '.$child->getAttribute('description');
							}
						break;
						case 'derivedParam':
							$info = $child->getAttribute('buildchain');
							if ($isLeaf) $isParameter = true;
						break;

						case 'localParam':

							$globalStart = null;
							$globalStop = null;
							$timeRestriction = false;
							$specialNode = true;
							$isParameter = false;
							$needsArgs = false;
10200969   Roipoussiere   Remove whitespace...
218
							$isSpectra = false;
735c653b   Elena.Budnik   rank at observato...
219
							$isStack = false;
e57cb025   Benjamin Renard   Fix most of error...
220
							$not_yet = false;
735c653b   Elena.Budnik   rank at observato...
221

10200969   Roipoussiere   Remove whitespace...
222
223
							if ($child->hasAttribute('desc'))
							{
735c653b   Elena.Budnik   rank at observato...
224
								$info = $child->getAttribute('desc');
10200969   Roipoussiere   Remove whitespace...
225
226
227
228

								if ($child->hasAttribute('dataStart') && $child->hasAttribute('dataStop'))
								{
									$info .= "<br/>Time Range: ".$child->getAttribute('dataStart')."-".$child->getAttribute('dataStop');
735c653b   Elena.Budnik   rank at observato...
229
								}
10200969   Roipoussiere   Remove whitespace...
230

735c653b   Elena.Budnik   rank at observato...
231
232
233
								if ($child->getAttribute('dataStart') == 'depending on mission')
								{
									$info .= "<br/>Time Range: ".$child->getAttribute('dataStart');
10200969   Roipoussiere   Remove whitespace...
234
235
236
								}

								if ($child->getAttribute('restriction') > 1)
735c653b   Elena.Budnik   rank at observato...
237
238
239
240
241
								{
									$restricted  = $child->getAttribute('restriction');
									$info .= "<br/><b>Time Restriction</b>: -$restricted days";
								}
							}
10200969   Roipoussiere   Remove whitespace...
242

735c653b   Elena.Budnik   rank at observato...
243
244
							if ($child->hasAttribute('units')) $info = $child->getAttribute('units');

10200969   Roipoussiere   Remove whitespace...
245
							if ($child->tagName == 'parameter')
735c653b   Elena.Budnik   rank at observato...
246
247
248
249
250
251
252
							{
								$isParameter = true;
								$isScatter = true;

								if ($child->parentNode->hasAttribute('dataStart'))
								{
									$globalStart = $child->parentNode->getAttribute('dataStart');
10200969   Roipoussiere   Remove whitespace...
253
									$globalStop = $child->parentNode->getAttribute('dataStop');
735c653b   Elena.Budnik   rank at observato...
254
255
256
257
258
								}

								if ($child->parentNode->getAttribute('restriction') > 1 )
								{
									$timeRestriction = true;
10200969   Roipoussiere   Remove whitespace...
259
260
261

								}
								/*------------------- to show not tested parameters ------*/
735c653b   Elena.Budnik   rank at observato...
262
								if ($child->getAttribute('tbd'))
10200969   Roipoussiere   Remove whitespace...
263
264
									$info .= "<br/><b>Not tested yet</b>";
								/*------------------- --------------------------------------*/
735c653b   Elena.Budnik   rank at observato...
265
							}
10200969   Roipoussiere   Remove whitespace...
266

735c653b   Elena.Budnik   rank at observato...
267
268
269
270
271
272
273
274
275
							$component_info = array();
							if ($child->tagName == 'component')
							{
								$isParameter = true;
								$isScatter = true;

								if ($child->parentNode->parentNode->hasAttribute('dataStart'))
								{
									$globalStart = $child->parentNode->parentNode->getAttribute('dataStart');
10200969   Roipoussiere   Remove whitespace...
276
277
									$globalStop = $child->parentNode->parentNode->getAttribute('dataStop');
								}
735c653b   Elena.Budnik   rank at observato...
278
279
280

								if ($child->parentNode->parentNode->getAttribute('restriction') > 1)
								{
10200969   Roipoussiere   Remove whitespace...
281
282
									$timeRestriction = true;
								}
735c653b   Elena.Budnik   rank at observato...
283
284
285
286
287

								if ($child->hasAttribute("index1"))
									$component_info["index1"] = $child->getAttribute('index1');
								if ($child->hasAttribute("index2"))
									$component_info["index2"] = $child->getAttribute('index2');
10200969   Roipoussiere   Remove whitespace...
288

735c653b   Elena.Budnik   rank at observato...
289
290
								$component_info["parentId"] = $child->parentNode->getAttribute('xml:id');
							}
10200969   Roipoussiere   Remove whitespace...
291

735c653b   Elena.Budnik   rank at observato...
292
							if ($child->tagName == 'parameter' && $child->hasChildNodes()) $isScatter = false;
10200969   Roipoussiere   Remove whitespace...
293
294

							if ($child->tagName == 'parameter' && $child->hasAttribute('display_type'))
735c653b   Elena.Budnik   rank at observato...
295
							{
10200969   Roipoussiere   Remove whitespace...
296
								if ($child->getAttribute('display_type') == 'spectrogram')
735c653b   Elena.Budnik   rank at observato...
297
								{
10200969   Roipoussiere   Remove whitespace...
298
299
										$needsArgs = true;
										$isSpectra = true;
735c653b   Elena.Budnik   rank at observato...
300
301
										$isScatter = false;
								}
10200969   Roipoussiere   Remove whitespace...
302
303
								elseif ($child->getAttribute('display_type') == 'stackplot')
								{
735c653b   Elena.Budnik   rank at observato...
304
305
306
										$isStack = true;
										$isScatter = false;
								}
10200969   Roipoussiere   Remove whitespace...
307
308
309
							}

							if ($isParameter)
735c653b   Elena.Budnik   rank at observato...
310
							{
735c653b   Elena.Budnik   rank at observato...
311
312
								$objectMgr = new AliasMgr();
								$alias = $objectMgr->getAlias($id);
10200969   Roipoussiere   Remove whitespace...
313
314

								$childrenToReturn[] = array('text' => $name,'alias' => $alias,
735c653b   Elena.Budnik   rank at observato...
315
316
317
318
319
									'id' => $id,'nodeType' => $nodeType, 'info' => $info, "component_info" => $component_info,
									'globalStart' => $globalStart, 'globalStop' => $globalStop, 'timeRestriction' => $timeRestriction,
									'leaf' => $isLeaf, 'isParameter' => $isParameter, 'isScatter' => $isScatter,
									'isSpectra' => $isSpectra,'isStack' => $isStack, 'needsArgs' => $needsArgs, 'help' => $help, 'notyet' => $not_yet);
							}
10200969   Roipoussiere   Remove whitespace...
320
							else
735c653b   Elena.Budnik   rank at observato...
321
							{
10200969   Roipoussiere   Remove whitespace...
322
								if ($child->tagName == 'mission' || $child->tagName == 'observatory')
735c653b   Elena.Budnik   rank at observato...
323
324
325
326
327
328
329
330
								{
									$disable = $child->hasAttribute('restriction');
									$rank = $child->getAttribute('rank');
								}
								else
								{
									$disable = $child->hasAttribute('restriction');
								}
10200969   Roipoussiere   Remove whitespace...
331

735c653b   Elena.Budnik   rank at observato...
332
333
334
								if ($disable)
								{
									if ($disable == 1) {
abda054b   Elena.Budnik   correct message
335
										$info .=  "<br/><b>Sorry ! Not finished yet...</b>";
735c653b   Elena.Budnik   rank at observato...
336
									}
10200969   Roipoussiere   Remove whitespace...
337
338
									else {
										$disable = false;
735c653b   Elena.Budnik   rank at observato...
339
340
341
									}
								}

10200969   Roipoussiere   Remove whitespace...
342
343
								$childrenToReturn[] = array('text' => $name, 'id' => $id,'nodeType' => $nodeType,  'info' => $info,
									'leaf' => false, 'help' => $help, 'disable' => $disable, 'rank' => $rank);
735c653b   Elena.Budnik   rank at observato...
344
345
346
347
							}
						break;

						case 'remoteSimuParam' :
10200969   Roipoussiere   Remove whitespace...
348

bf74fc2d   Elena.Budnik   IMPEX
349
							$globalStart = null;
6657f68b   Elena.Budnik   monitor impex ser...
350
							$service_down = false;
735c653b   Elena.Budnik   rank at observato...
351
							$isSimulation = true;
10200969   Roipoussiere   Remove whitespace...
352
353

			            if ($child->getAttribute('isAddable')) // 'spase://IMPEX/SimulationModel/FMI/GUMICS'
735c653b   Elena.Budnik   rank at observato...
354
355
356
357
							{
								$isLeaf = false;
								$isAddable = true;
							}
10200969   Roipoussiere   Remove whitespace...
358
359

							if ($child->tagName == 'dataCenter')
735c653b   Elena.Budnik   rank at observato...
360
							{
10200969   Roipoussiere   Remove whitespace...
361
								if ($child->getAttribute('isSimulation'))
6657f68b   Elena.Budnik   monitor impex ser...
362
								{
10200969   Roipoussiere   Remove whitespace...
363
364
									$service_down = !($child->getAttribute('available'));
									break;
6657f68b   Elena.Budnik   monitor impex ser...
365
								}
10200969   Roipoussiere   Remove whitespace...
366
								else
735c653b   Elena.Budnik   rank at observato...
367
368
369
370
371
								{
									$skip = true;
									break;
								}
							}
10200969   Roipoussiere   Remove whitespace...
372
373

							if ($child->hasAttribute('rank'))
735c653b   Elena.Budnik   rank at observato...
374
375
376
							{
								$rank = $child->getAttribute('rank');
							}
10200969   Roipoussiere   Remove whitespace...
377

bf74fc2d   Elena.Budnik   IMPEX
378
379
							if ( $child->tagName == 'parameter')
							{
a0f13ed1   Elena.Budnik   small format + ti...
380
								if ($child->parentNode->hasAttribute('dataStart'))
bf74fc2d   Elena.Budnik   IMPEX
381
									{
a0f13ed1   Elena.Budnik   small format + ti...
382
383
										$globalStart = $child->parentNode->getAttribute('dataStart');
										$globalStop = $child->parentNode->getAttribute('dataStop');
bf74fc2d   Elena.Budnik   IMPEX
384
385
									}
							}
10200969   Roipoussiere   Remove whitespace...
386

bf74fc2d   Elena.Budnik   IMPEX
387
388
389
390
391
							if ( $child->tagName == 'component')
							{
								if ($child->parentNode->parentNode->hasAttribute('dataStart'))
									{
										$globalStart = $child->parentNode->parentNode->getAttribute('dataStart');
10200969   Roipoussiere   Remove whitespace...
392
										$globalStop = $child->parentNode->parentNode->getAttribute('dataStop');
bf74fc2d   Elena.Budnik   IMPEX
393
394
									}
							}
10200969   Roipoussiere   Remove whitespace...
395

735c653b   Elena.Budnik   rank at observato...
396
						case 'remoteParam' :
10200969   Roipoussiere   Remove whitespace...
397
398

							if ($child->getAttribute('isSimulation') && $child->tagName == 'dataCenter')
735c653b   Elena.Budnik   rank at observato...
399
400
401
402
403
404
405
							{
								$skip = true;
								break;
							}

							$isDeletable = $child->hasAttribute('isDeletable');
							$specialNode = true;
10200969   Roipoussiere   Remove whitespace...
406
407
408
409
410
							$isParameter = false;

							$isSpectra = false;

							switch ($id)
735c653b   Elena.Budnik   rank at observato...
411
							{
10200969   Roipoussiere   Remove whitespace...
412
								case 'CDAWEB'  :
735c653b   Elena.Budnik   rank at observato...
413
414
415
416
417
								case 'THEMIS' :
									$rank = 5;
									break;
								case 'MAPSKP' :
									$rank = 9;
10200969   Roipoussiere   Remove whitespace...
418
									break;
735c653b   Elena.Budnik   rank at observato...
419
420
								default:
							}
10200969   Roipoussiere   Remove whitespace...
421

735c653b   Elena.Budnik   rank at observato...
422
423
							$info = $child->getAttribute('desc');

10200969   Roipoussiere   Remove whitespace...
424
425
							if ($info && !$isSimulation)
							{
735c653b   Elena.Budnik   rank at observato...
426
								$info = str_replace(';', "<br/>Time Range: ", $info);
10200969   Roipoussiere   Remove whitespace...
427
428
429
							}

							if (($child->tagName == 'parameter') || ($child->tagName == 'component'))
735c653b   Elena.Budnik   rank at observato...
430
431
							{
								$isParameter = true;
10200969   Roipoussiere   Remove whitespace...
432
								$isScatter = true;
735c653b   Elena.Budnik   rank at observato...
433
							}
10200969   Roipoussiere   Remove whitespace...
434

9a63b7f6   Elena.Budnik   needsArgs to Simu...
435
							$needsArgs =  $child->getAttribute('needsArgs');
735c653b   Elena.Budnik   rank at observato...
436
437

							if (($child->tagName == 'parameter' && $child->hasChildNodes()) || $needsArgs) $isScatter = false;
10200969   Roipoussiere   Remove whitespace...
438
439

							if ($remoteBase)
735c653b   Elena.Budnik   rank at observato...
440
							{
10200969   Roipoussiere   Remove whitespace...
441
								if ($child->tagName == 'dataset') $isRemoteDataSet = true;
735c653b   Elena.Budnik   rank at observato...
442
							}
a0f13ed1   Elena.Budnik   small format + ti...
443
444
445
446
447
448
449
							
							if ($child->tagName == 'parameter'){
								if ($child->parentNode->hasAttribute('dataStart')){
									$globalStart = date('Y-m-d\TH:i:s\Z', strtotime($child->parentNode->getAttribute('dataStart')));
									$globalStop = date('Y-m-d\TH:i:s\Z',  strtotime($child->parentNode->getAttribute('dataStop')));
								}
							}
735c653b   Elena.Budnik   rank at observato...
450

a0f13ed1   Elena.Budnik   small format + ti...
451
452
453
454
455
456
457
							if ( $child->tagName == 'component'){
								if ($child->parentNode->parentNode->hasAttribute('dataStart')){
									$globalStart = date('Y-m-d\TH:i:s\Z', strtotime($child->parentNode->getAttribute('dataStart')));
									$globalStop = date('Y-m-d\TH:i:s\Z',  strtotime($child->parentNode->getAttribute('dataStop')));
								}
							}
							
10200969   Roipoussiere   Remove whitespace...
458
							if ($isParameter)
735c653b   Elena.Budnik   rank at observato...
459
							{
10200969   Roipoussiere   Remove whitespace...
460
								$disable = $child->parentNode->getAttribute('disabled');
735c653b   Elena.Budnik   rank at observato...
461
462
463
464
465
								$objectMgr = new AliasMgr();
								$alias = $objectMgr->getAlias($id);

								if ($child->hasAttribute('display_type') && $child->getAttribute('display_type') == 'spectrogram')
								{
10200969   Roipoussiere   Remove whitespace...
466
									$needsArgs = true;
735c653b   Elena.Budnik   rank at observato...
467
468
									$isScatter = false;
									$isSpectra = true;
10200969   Roipoussiere   Remove whitespace...
469
								}
bf74fc2d   Elena.Budnik   IMPEX
470
								if ($globalStart)
10200969   Roipoussiere   Remove whitespace...
471
								 $childrenToReturn[] = array('text' => $name,'alias' => $alias,
bf74fc2d   Elena.Budnik   IMPEX
472
										'id' => $id,'nodeType' => $nodeType,  'info' => $info, 'help' => $help,  'globalStart' => $globalStart,
10200969   Roipoussiere   Remove whitespace...
473
										'globalStop' => $globalStop, 'leaf' => $isLeaf, 'disable' => $disable, 'isParameter' => $isParameter,
bf74fc2d   Elena.Budnik   IMPEX
474
475
										'isScatter' => $isScatter, 'isSpectra' => $isSpectra, 'needsArgs' => $needsArgs, "component_info" => $component_info);
								else
10200969   Roipoussiere   Remove whitespace...
476
									$childrenToReturn[] = array('text' => $name,'alias' => $alias,
bf74fc2d   Elena.Budnik   IMPEX
477
										'id' => $id,'nodeType' => $nodeType,  'info' => $info, 'help' => $help,
10200969   Roipoussiere   Remove whitespace...
478
										'leaf' => $isLeaf, 'disable' => $disable, 'isParameter' => $isParameter,
bf74fc2d   Elena.Budnik   IMPEX
479
										'isScatter' => $isScatter, 'isSpectra' => $isSpectra, 'needsArgs' => $needsArgs, "component_info" => $component_info);
735c653b   Elena.Budnik   rank at observato...
480
							}
10200969   Roipoussiere   Remove whitespace...
481
482
							else
							{
e57cb025   Benjamin Renard   Fix most of error...
483
								$restricted = FALSE;
9e3cbd95   Elena.Budnik   merge AMDA_IHM AM...
484
								
735c653b   Elena.Budnik   rank at observato...
485
								if ($child->tagName == 'dataset')
6657f68b   Elena.Budnik   monitor impex ser...
486
								{
735c653b   Elena.Budnik   rank at observato...
487
									$nonavailable = ($child->getAttribute('disabled'));
6657f68b   Elena.Budnik   monitor impex ser...
488
								}
735c653b   Elena.Budnik   rank at observato...
489
								else
6657f68b   Elena.Budnik   monitor impex ser...
490
								{
735c653b   Elena.Budnik   rank at observato...
491
									$nonavailable = false;
6657f68b   Elena.Budnik   monitor impex ser...
492
								}
10200969   Roipoussiere   Remove whitespace...
493

735c653b   Elena.Budnik   rank at observato...
494
495
496
497
498
499
								if ($nonavailable)
									$info .= "<br/><b>Not available yet</b>";

								if ($child->getAttribute('url'))
									$info .= "<br/>".$child->getAttribute('url');

10200969   Roipoussiere   Remove whitespace...
500
								if ($child->hasAttribute('obsolete'))
735c653b   Elena.Budnik   rank at observato...
501
502
503
504
505
506
507
508
								{
									$info = $child->getAttribute('desc');
									$obsolete = true;
								}
								else
									$obsolete = false;

								$disable = $restricted || $nonavailable || $obsolete;
10200969   Roipoussiere   Remove whitespace...
509

735c653b   Elena.Budnik   rank at observato...
510
								$childrenToReturn[] = array('text' => $name, 'id' => $id,'nodeType' => $nodeType,  'isAddable' => $isAddable,
10200969   Roipoussiere   Remove whitespace...
511
512
513
								'info' => $info, 'leaf' => false, 'isRemoteDataSet' => $isRemoteDataSet, 'disable' => $disable,
								'isSimulation' => $isSimulation, 'rank' => $rank, 'isDeletable' => $isDeletable, 'help' => $help);
							}
735c653b   Elena.Budnik   rank at observato...
514
						break;
10200969   Roipoussiere   Remove whitespace...
515
516
517

						case 'myData' :
							$info = $child->hasAttribute('info') ? $child->getAttribute('info') : $child->nodeValue;
735c653b   Elena.Budnik   rank at observato...
518
519
520
521
522
523
524
525
526
527
528
						break;

						case 'myDataParam' :

							$globalStart = null;
							$globalStop = null;
							$specialNode = true;
							$size = $child->getAttribute('size');
							$isScatter = $size == 1;
							$mask = $child->getAttribute('mask');
							$isSpectra = false;
10200969   Roipoussiere   Remove whitespace...
529
530

							if ($isLeaf)
735c653b   Elena.Budnik   rank at observato...
531
532
533
534
535
536
							{
									$isParameter = true;
									$info = "Size: ".$size."<br/>".$child->getAttribute('desc')."<br/> Mask: ".$mask;
									$isSpectra = $child->getAttribute('plottype') === 'Spectra';
							}

10200969   Roipoussiere   Remove whitespace...
537
							if ($child->hasAttribute('desc'))
735c653b   Elena.Budnik   rank at observato...
538
539
540
541
542
							{
									$globalStart = substr($child->getAttribute('desc'), 0, 19);
									$globalStop =  substr($child->getAttribute('desc'), 20);
							}

10200969   Roipoussiere   Remove whitespace...
543
							$childrenToReturn[] = array('text' => $name, 'size' =>  $size, 'id' => $id,
735c653b   Elena.Budnik   rank at observato...
544
								'globalStart' => $globalStart, 'globalStop' => $globalStop,
10200969   Roipoussiere   Remove whitespace...
545
								'nodeType' => $nodeType, 'info' => $info, 'isScatter' => $isScatter, 'leaf' => $isLeaf,
735c653b   Elena.Budnik   rank at observato...
546
547
548
								'isParameter' => $isParameter, 'linkedMask' => $mask, 'isSpectra' => $isSpectra);

						break;
10200969   Roipoussiere   Remove whitespace...
549
						default:
735c653b   Elena.Budnik   rank at observato...
550
					}
10200969   Roipoussiere   Remove whitespace...
551
552

					if (!$specialNode && !$skip)
735c653b   Elena.Budnik   rank at observato...
553
					{
10200969   Roipoussiere   Remove whitespace...
554
						if ($child->hasAttribute('desc'))
735c653b   Elena.Budnik   rank at observato...
555
							$info = $child->getAttribute('desc');
10200969   Roipoussiere   Remove whitespace...
556
557

						if ($isSimulation && $service_down)
6657f68b   Elena.Budnik   monitor impex ser...
558
559
560
						{
							$info = "<b>Service is currently down</b>";
						}
10200969   Roipoussiere   Remove whitespace...
561
562

						$childrenToReturn[] = array('text' => $name, 'id' => $id, 'nodeType' => $nodeType, 'info' => $info,
6657f68b   Elena.Budnik   monitor impex ser...
563
													'help' => $help, 'leaf' => $isLeaf, 'isParameter' => $isParameter);
735c653b   Elena.Budnik   rank at observato...
564
565
566
					}
				}
				// if $childrenToReturn we have to return []
e57cb025   Benjamin Renard   Fix most of error...
567
				if (empty($childrenToReturn))
10200969   Roipoussiere   Remove whitespace...
568
				{
735c653b   Elena.Budnik   rank at observato...
569
570
571
					$childrenToReturn = array('nodeType' => $nodeType, 'text' => null);
				}
			}
16035364   Benjamin Renard   First commit
572
      return  $childrenToReturn;
735c653b   Elena.Budnik   rank at observato...
573
	}
16035364   Benjamin Renard   First commit
574

0dc31ba8   Elena.Budnik   remoteParamManage...
575
576
577
578
579
	/*
	*  add Remote Parameter to user RemoteParams.xml
	*  send request to DDServer to AddVi if Vi doesn't exist
	*  create Remote Parameter Description	
	*/
10200969   Roipoussiere   Remove whitespace...
580
	public  function saveTree($obj)
735c653b   Elena.Budnik   rank at observato...
581
	{
0dc31ba8   Elena.Budnik   remoteParamManage...
582
		$paramMgr = new RemoteParamManager();
10200969   Roipoussiere   Remove whitespace...
583
		return $paramMgr->saveTree($obj);
735c653b   Elena.Budnik   rank at observato...
584
	}
0dc31ba8   Elena.Budnik   remoteParamManage...
585
586
587
588
	
	/*
	*  delete Remote Parameter from user RemoteParams.xml
	*/
10200969   Roipoussiere   Remove whitespace...
589
590
	public  function deleteFromTree($obj)
	{
0dc31ba8   Elena.Budnik   remoteParamManage...
591
		$paramMgr = new RemoteParamManager();
10200969   Roipoussiere   Remove whitespace...
592
		return $paramMgr->deleteFromTree($obj);
9a63b7f6   Elena.Budnik   needsArgs to Simu...
593
	}
0dc31ba8   Elena.Budnik   remoteParamManage...
594
595
596
597
598
		
	public  function doNothing($obj)
	{
		return array("res" => 'ok');
	}
16035364   Benjamin Renard   First commit
599

0dc31ba8   Elena.Budnik   remoteParamManage...
600
601
602
	/*
	*  get temporary object from Upload
	*/
9a63b7f6   Elena.Budnik   needsArgs to Simu...
603
	public  function getUploadedObject($name, $format, $nodeType)
10200969   Roipoussiere   Remove whitespace...
604
605
	{
		switch ($nodeType)
9a63b7f6   Elena.Budnik   needsArgs to Simu...
606
		{
10200969   Roipoussiere   Remove whitespace...
607
608
			case 'timeTable' :
				$objectMgr = new TimeTableMgr();
9a63b7f6   Elena.Budnik   needsArgs to Simu...
609
				break;
10200969   Roipoussiere   Remove whitespace...
610
611
612
613
614
			case 'myDataParam' :
				$objectMgr = new FilesMgr();
				break;
			case 'catalog' :
				$objectMgr = new CatalogMgr();
9a63b7f6   Elena.Budnik   needsArgs to Simu...
615
				break;
9a63b7f6   Elena.Budnik   needsArgs to Simu...
616
617
618
			default:
				return array("error" => $nodeType." NOT_IMPLEMENTED_YET");
		}
bf74fc2d   Elena.Budnik   IMPEX
619
		return  $objectMgr->getUploadedObject($name, $format, true);
10200969   Roipoussiere   Remove whitespace...
620
	}
16035364   Benjamin Renard   First commit
621

0dc31ba8   Elena.Budnik   remoteParamManage...
622
623
624
	/*
	*  fill ascii file into grid
	*/
10200969   Roipoussiere   Remove whitespace...
625
626
627
	public  function getAsciiFile($obj)
	{
		$objectMgr = new FilesMgr();
bf74fc2d   Elena.Budnik   IMPEX
628
		return  $objectMgr->getAsciiFile($obj->fileName);
735c653b   Elena.Budnik   rank at observato...
629
	}
10200969   Roipoussiere   Remove whitespace...
630
631
632
633

	public function getMyParamInfo($object)
	{
		$objectMgr = new FilesMgr();
bf74fc2d   Elena.Budnik   IMPEX
634
		return  $objectMgr->getParamInfo($object);
10200969   Roipoussiere   Remove whitespace...
635
	}
16035364   Benjamin Renard   First commit
636

0dc31ba8   Elena.Budnik   remoteParamManage...
637
638
639
	/*
	*  get temporary object from Search
	*/
10200969   Roipoussiere   Remove whitespace...
640
641
642
	public  function getTmpObject($folderId, $name, $nodeType)
	{
		switch ($nodeType)
735c653b   Elena.Budnik   rank at observato...
643
		{
10200969   Roipoussiere   Remove whitespace...
644
645
646
			case 'timeTable' :
				$objectMgr = new TimeTableMgr();
			break;
735c653b   Elena.Budnik   rank at observato...
647
			case 'catalog' :
10200969   Roipoussiere   Remove whitespace...
648
649
				$objectMgr = new CatalogMgr();
			break;
735c653b   Elena.Budnik   rank at observato...
650
651
652
			default:
				return array("error" => $nodeType." NOT_IMPLEMENTED_YET");
		}
bf74fc2d   Elena.Budnik   IMPEX
653
		return  $objectMgr->getTmpObject($folderId, $name, true);
fdf1413b   Elena.Budnik   TT download
654
	}
735c653b   Elena.Budnik   rank at observato...
655

10200969   Roipoussiere   Remove whitespace...
656
657
658
659

	public  function getObject($id, $nodeType)
	{
		switch ($nodeType)
735c653b   Elena.Budnik   rank at observato...
660
661
		{
			case 'myDataParam':
10200969   Roipoussiere   Remove whitespace...
662
663
			case 'derivedParam' :
				$objectMgr = new DerivedParamMgr($nodeType);
735c653b   Elena.Budnik   rank at observato...
664
				break;
10200969   Roipoussiere   Remove whitespace...
665
			case 'timeTable' :
735c653b   Elena.Budnik   rank at observato...
666
			case 'sharedtimeTable' :
10200969   Roipoussiere   Remove whitespace...
667
668
				$objectMgr = new TimeTableMgr();
				break;
735c653b   Elena.Budnik   rank at observato...
669
670
			case 'catalog' :
			case 'sharedcatalog' :
10200969   Roipoussiere   Remove whitespace...
671
672
673
				$objectMgr = new CatalogMgr();
				break;
			case 'condition' :
735c653b   Elena.Budnik   rank at observato...
674
			case 'request' :
10200969   Roipoussiere   Remove whitespace...
675
676
				$objectMgr = new RequestMgr($nodeType);
				break;
9e3cbd95   Elena.Budnik   merge AMDA_IHM AM...
677
			case 'bkgWorks' :	
735c653b   Elena.Budnik   rank at observato...
678
679
680
				return $this->executeRequest($id, FunctionTypeEnumClass::PROCESSGETINFO);
				break;
			case 'myData' :
10200969   Roipoussiere   Remove whitespace...
681
				$objectMgr = new FilesMgr();
735c653b   Elena.Budnik   rank at observato...
682
				break;
10200969   Roipoussiere   Remove whitespace...
683
			default:
735c653b   Elena.Budnik   rank at observato...
684
685
				return array("error" => $nodeType." NOT_IMPLEMENTED_YET");
		}
bf74fc2d   Elena.Budnik   IMPEX
686
		return  $objectMgr->getObject($id, $nodeType);
fdf1413b   Elena.Budnik   TT download
687
	}
10200969   Roipoussiere   Remove whitespace...
688

16035364   Benjamin Renard   First commit
689
690
691
/*
*   $obj = { id: node.id, leaf: node.leaf, nodeType: node.nodeType }
*/
10200969   Roipoussiere   Remove whitespace...
692
693
694
695
696
697
698
	public  function deleteObject($obj)
	{
		switch ($obj->nodeType)
		{
			case 'myDataParam' :
			case 'derivedParam' :
				$objectMgr = new DerivedParamMgr($obj->nodeType);
735c653b   Elena.Budnik   rank at observato...
699
				break;
10200969   Roipoussiere   Remove whitespace...
700
701
702
703
704
			case 'timeTable' :
				$objectMgr = new TimeTableMgr();
				break;
			case 'catalog' :
				$objectMgr = new CatalogMgr();
735c653b   Elena.Budnik   rank at observato...
705
				break;
10200969   Roipoussiere   Remove whitespace...
706
			case 'condition' :
735c653b   Elena.Budnik   rank at observato...
707
			case 'request' :
10200969   Roipoussiere   Remove whitespace...
708
				$objectMgr = new RequestMgr($obj->nodeType);
735c653b   Elena.Budnik   rank at observato...
709
710
711
712
				break;
			case 'alias' :
				$objectMgr = new AliasMgr();
				$obj->id = substr($obj->id,strlen('alias_'));
10200969   Roipoussiere   Remove whitespace...
713
				break;
735c653b   Elena.Budnik   rank at observato...
714
			case 'bkgWorks' :
735c653b   Elena.Budnik   rank at observato...
715
716
717
				return $this->executeRequest($obj, FunctionTypeEnumClass::PROCESSDELETE);

			case 'myData' :
16035364   Benjamin Renard   First commit
718
				$objectMgr = new FilesMgr();
735c653b   Elena.Budnik   rank at observato...
719
720
721
722
723
724
				break;
			default:
					return array("error" => $obj->nodeType." NOT_IMPLEMENTED_YET");
		}
		return  $objectMgr -> deleteObject($obj);
	}
16035364   Benjamin Renard   First commit
725
726
727
728

/*
*   $obj = { id: node.id, old_name: node.text, name: value,  parent : node.parentNode.id, leaf: node.leaf, nodeType: node.nodeType }
*/
10200969   Roipoussiere   Remove whitespace...
729
730
731
	public  function renameObject($obj)
	{
		switch ($obj->nodeType)
735c653b   Elena.Budnik   rank at observato...
732
		{
10200969   Roipoussiere   Remove whitespace...
733

16035364   Benjamin Renard   First commit
734
		  case 'myDataParam' :
10200969   Roipoussiere   Remove whitespace...
735
736
737
738
739
		  case 'derivedParam' :
			   $objectMgr = new DerivedParamMgr($obj->nodeType);
			   break;
		  case 'timeTable' :
			   $objectMgr = new TimeTableMgr();
16035364   Benjamin Renard   First commit
740
			   break;
10200969   Roipoussiere   Remove whitespace...
741
742
		  case 'catalog' :
			   $objectMgr = new CatalogMgr();
d18b535d   elena   catalog draft + c...
743
			   break;
10200969   Roipoussiere   Remove whitespace...
744
745
746
		  case 'condition' :
		  case 'request' :
			   $objectMgr = new RequestMgr($obj->nodeType);
16035364   Benjamin Renard   First commit
747
748
			   break;
		  case 'alias' :
10200969   Roipoussiere   Remove whitespace...
749
750
		  	   $objectMgr = new AliasMgr();
		  	   break;
16035364   Benjamin Renard   First commit
751
752
		  default:
			    return array("error" => $obj->nodeType." NOT_IMPLEMENTED_YET");
735c653b   Elena.Budnik   rank at observato...
753
		}
16035364   Benjamin Renard   First commit
754

735c653b   Elena.Budnik   rank at observato...
755
756
		return  $objectMgr -> renameObject($obj);
	}
16035364   Benjamin Renard   First commit
757

10200969   Roipoussiere   Remove whitespace...
758
/*
16035364   Benjamin Renard   First commit
759
760
*   $obj = { name: obj.name, obj.nodeType, obj.leaf (??), OBJ DEPENDENT ATTRIBUTES }
*/
10200969   Roipoussiere   Remove whitespace...
761
762
763
	public  function createObject($obj, $folder)
	{
		switch ($obj->nodeType)
9a63b7f6   Elena.Budnik   needsArgs to Simu...
764
		{
10200969   Roipoussiere   Remove whitespace...
765
			case 'myDataParam' :
9a63b7f6   Elena.Budnik   needsArgs to Simu...
766
			case 'derivedParam' :
10200969   Roipoussiere   Remove whitespace...
767
				if ($obj->nodeType == 'derivedParam' &&  $this->amdaStat->success)
9a63b7f6   Elena.Budnik   needsArgs to Simu...
768
						$this->amdaStat->addTask('create', $this->user, null);
10200969   Roipoussiere   Remove whitespace...
769
770
771
772
773
774
775
				$objectMgr = new DerivedParamMgr($obj->nodeType);
				break;
			case 'timeTable' :
				$objectMgr = new TimeTableMgr();
				break;
			case 'catalog' :
				$objectMgr = new CatalogMgr();
16035364   Benjamin Renard   First commit
776
			   break;
9a63b7f6   Elena.Budnik   needsArgs to Simu...
777
			case 'condition' :
10200969   Roipoussiere   Remove whitespace...
778
779
780
			case 'request' :
				$objectMgr = new RequestMgr($obj->nodeType);
				break;
9a63b7f6   Elena.Budnik   needsArgs to Simu...
781
			case 'alias' :
10200969   Roipoussiere   Remove whitespace...
782
783
				$objectMgr = new AliasMgr();
				break;
9a63b7f6   Elena.Budnik   needsArgs to Simu...
784
785
786
787
788
			default:
				return array("error" => $obj->nodeType." NOT_IMPLEMENTED_YET");
		}
		return  $objectMgr -> createObject($obj, $folder);
	}
16035364   Benjamin Renard   First commit
789

10200969   Roipoussiere   Remove whitespace...
790
/*
16035364   Benjamin Renard   First commit
791
792
*   $obj = { id:obj.id, name: obj.name, obj.nodeType, obj.leaf (??), OBJ DEPENDENT ATTRIBUTES }
*/
10200969   Roipoussiere   Remove whitespace...
793
	public  function modifyObject($obj)
9a63b7f6   Elena.Budnik   needsArgs to Simu...
794
	{
10200969   Roipoussiere   Remove whitespace...
795
796
797
798
799
		switch ($obj->nodeType)
		{
			case 'myDataParam' :
			case 'derivedParam' :
				$objectMgr = new DerivedParamMgr($obj->nodeType);
9a63b7f6   Elena.Budnik   needsArgs to Simu...
800
				break;
10200969   Roipoussiere   Remove whitespace...
801
802
			case 'timeTable' :
				$objectMgr = new TimeTableMgr();
9a63b7f6   Elena.Budnik   needsArgs to Simu...
803
				break;
10200969   Roipoussiere   Remove whitespace...
804
805
806
807
			case 'catalog' :
				$objectMgr = new CatalogMgr();
				break;
			case 'condition' :
9a63b7f6   Elena.Budnik   needsArgs to Simu...
808
			case 'request' :
10200969   Roipoussiere   Remove whitespace...
809
				$objectMgr = new RequestMgr($obj->nodeType);
9a63b7f6   Elena.Budnik   needsArgs to Simu...
810
811
812
813
814
				break;
			default:
				return array("error" => $obj->nodeType." NOT_IMPLEMENTED_YET");
		}
		return  $objectMgr -> modifyObject($obj);
10200969   Roipoussiere   Remove whitespace...
815
	}
16035364   Benjamin Renard   First commit
816
817
818
819
820
821
822
823
824
825
/*
 * {obj.name, obj.nodeType, obj.leaf}
 */
    public function validNameObject($obj) {
		switch ($obj->nodeType) {
			case 'myDataParam' :
			case 'derivedParam' :
				$objectMgr = new DerivedParamMgr($obj->nodeType);
				break;
			case 'timeTable' :
d18b535d   elena   catalog draft + c...
826
			case 'sharedtimeTable' :
16035364   Benjamin Renard   First commit
827
828
				$objectMgr = new TimeTableMgr();
				break;
d18b535d   elena   catalog draft + c...
829
			case 'catalog' :
169f14d2   Benjamin Renard   Add shared object...
830
			case 'sharedcatalog' :
d18b535d   elena   catalog draft + c...
831
832
				$objectMgr = new CatalogMgr();
				break;
16035364   Benjamin Renard   First commit
833
834
835
836
837
838
839
840
841
842
843
844
			case 'condition' :
			case 'request' :
				$objectMgr = new RequestMgr($obj->nodeType);
				break;
			default:
				return array("error" => $obj->nodeType." NOT_IMPLEMENTED_YET");
		}

		return  $objectMgr -> validNameObject($obj);
    }

/*
bae6f5da   Nathanael Jourdane   bugFix fileName f...
845
*   Get running jobs
16035364   Benjamin Renard   First commit
846
*/
bae6f5da   Nathanael Jourdane   bugFix fileName f...
847
	public function getJobs($obj = null)
6acb8d2a   Elena.Budnik   checkRequest in R...
848
	{
9e3cbd95   Elena.Budnik   merge AMDA_IHM AM...
849
		$obj = (object) array();	
10200969   Roipoussiere   Remove whitespace...
850
		return $this->executeRequest($obj, FunctionTypeEnumClass::PROCESSRUNNINGINFO);
6acb8d2a   Elena.Budnik   checkRequest in R...
851
	}
16035364   Benjamin Renard   First commit
852
853
854
855
856
857
858


	/* AKKA-KERNEL-INT
	Move user check from RequestMgr.php to AmdaAction.php
	*/
	private function checkUser($obj)
	{
32bb889b   Elena.Budnik   #5532 to process ...
859
		if (defined('NEWKERNEL_DEBUG') && NEWKERNEL_DEBUG){
16035364   Benjamin Renard   First commit
860
861
862
			$this->user = NEWKERNEL_DEBUG_USER;
			return array('success' => true);
		}
10200969   Roipoussiere   Remove whitespace...
863

16035364   Benjamin Renard   First commit
864
		if (isset($obj->username) && isset($obj->password) && isset($obj->sessionID))
735c653b   Elena.Budnik   rank at observato...
865
		{
e5ab198f   Nathanael Jourdane   simple getStatus
866
			$dd = new WSUserMgr();
fcdd1349   Elena.Budnik   merge with master
867
			$dd->init($obj->username,$obj->password,$obj->sessionID, false);
735c653b   Elena.Budnik   rank at observato...
868
		}
a21497cc   Elena.Budnik   redmine #5645
869
		else {
16035364   Benjamin Renard   First commit
870
			$dd = new UserMgr();
a21497cc   Elena.Budnik   redmine #5645
871
872
			$dd->setSpecialSettings();
		}
10200969   Roipoussiere   Remove whitespace...
873
874

		//TODO error handling
32bb889b   Elena.Budnik   #5532 to process ...
875
		if (($res = $dd->ddCheckUser()) != 0) {
10200969   Roipoussiere   Remove whitespace...
876
			if ($res == 156)
6acb8d2a   Elena.Budnik   checkRequest in R...
877
				return array('success' => false, 'message' => 'Your AMDA session is expired.<br/> Login please!');
16035364   Benjamin Renard   First commit
878

735c653b   Elena.Budnik   rank at observato...
879
880
			return array('success' => false, 'message' => 'ddLogin error: '.$res);
		}
16035364   Benjamin Renard   First commit
881

6acb8d2a   Elena.Budnik   checkRequest in R...
882
		if ($dd->user == 'impex')
16035364   Benjamin Renard   First commit
883
884
885
		{
			//if ($dd->getWsSize() > DISK_QUOTA * 100)
			//	error_log('Natacha! It is time to CLEAN UP IMPEX WS!',1,'nbourrel@irap.omp.eu');
e5ab198f   Nathanael Jourdane   simple getStatus
886
//			return array('success' => false, "message" => "AKKA-KERNEL-INT - WS support for IMPEx not implemented");
6acb8d2a   Elena.Budnik   checkRequest in R...
887
		}
32bb889b   Elena.Budnik   #5532 to process ...
888
		else {
a21497cc   Elena.Budnik   redmine #5645
889
			// check disk space 
6acb8d2a   Elena.Budnik   checkRequest in R...
890
			if ($dd->getWsSize() > DISK_QUOTA)
16035364   Benjamin Renard   First commit
891
				return array('success' => false, 'message' => 'Please clean up your workspace.<br/>No more space is available');
735c653b   Elena.Budnik   rank at observato...
892
		}
10200969   Roipoussiere   Remove whitespace...
893

735c653b   Elena.Budnik   rank at observato...
894
		$this->user = $dd->user;
10200969   Roipoussiere   Remove whitespace...
895

32bb889b   Elena.Budnik   #5532 to process ...
896
		return array('success' => true, 'userHost' => $dd->getIPclient());
16035364   Benjamin Renard   First commit
897
	}
10200969   Roipoussiere   Remove whitespace...
898

6acb8d2a   Elena.Budnik   checkRequest in R...
899
	private function executeRequest($obj, $function)
9e3cbd95   Elena.Budnik   merge AMDA_IHM AM...
900
	{ 
32bb889b   Elena.Budnik   #5532 to process ...
901
902
903
904
905
		// Check user if access to DD Server and / or possible 'space consuming' action
		if (  $function == FunctionTypeEnumClass::PARAMS ||
				$function == FunctionTypeEnumClass::ACTION ||
				$function == FunctionTypeEnumClass::PARAMSGEN )
		{
7ac3e07e   Elena.Budnik   do not check user...
906
907
908
909
			$res = $this->checkUser($obj);
			if (!$res['success']) return $res;
		}
		
16035364   Benjamin Renard   First commit
910
		$requestManager = new RequestManagerClass();
32bb889b   Elena.Budnik   #5532 to process ...
911
		try {
e57cb025   Benjamin Renard   Fix most of error...
912
			$res = $requestManager->runIHMRequest($this->user, !empty($res['userHost']) ? $res['userHost'] : NULL, $function, $obj);
9b69cb35   Nathanael Jourdane   Implement batch m...
913
		} catch (Exception $e) {
16035364   Benjamin Renard   First commit
914
			return array('success' => false, 'message' => 'Exception detected : '.$e->getMessage());
10200969   Roipoussiere   Remove whitespace...
915
		}
32bb889b   Elena.Budnik   #5532 to process ...
916
		
16035364   Benjamin Renard   First commit
917
918
		return $res;
	}
10200969   Roipoussiere   Remove whitespace...
919
920
921

/*
*    Main EXECUTE PROCEDURE
16035364   Benjamin Renard   First commit
922
*/
735c653b   Elena.Budnik   rank at observato...
923
924
	public  function execute($node, $obj)
	{
fdf1413b   Elena.Budnik   TT download
925
926
927
928
		// just convert TT / Catalog
		if ($obj->nodeType == "download" &&  $obj->downloadSrc == "1")
			return $this->executeRequest($obj, FunctionTypeEnumClass::TTCONVERT);
		else if (isset($obj->action))
16035364   Benjamin Renard   First commit
929
			return $this->executeRequest($obj, FunctionTypeEnumClass::ACTION);
10200969   Roipoussiere   Remove whitespace...
930
931
		else
		{
6acb8d2a   Elena.Budnik   checkRequest in R...
932
933
			$res = RequestMgr::checkRequest($obj);
			if (!$res['success']) return $res;
10200969   Roipoussiere   Remove whitespace...
934

16035364   Benjamin Renard   First commit
935
			return $this->executeRequest($obj, FunctionTypeEnumClass::PARAMS);
6acb8d2a   Elena.Budnik   checkRequest in R...
936
		}
fdf1413b   Elena.Budnik   TT download
937
	}
10200969   Roipoussiere   Remove whitespace...
938

16035364   Benjamin Renard   First commit
939
/*
a0b3d64e   Benjamin Renard   Derived parameter...
940
941
 * Generate derived parameter compilation
 */
735c653b   Elena.Budnik   rank at observato...
942
943
	public function compilParam($obj)
	{
735c653b   Elena.Budnik   rank at observato...
944
945
		return $this->executeRequest($obj, FunctionTypeEnumClass::PARAMSGEN);
	}
a0b3d64e   Benjamin Renard   Derived parameter...
946
947
948
949

/*
 * Delete derived parameter compilation
 */
735c653b   Elena.Budnik   rank at observato...
950
951
	public function compilParamDelete($obj)
	{
a0b3d64e   Benjamin Renard   Derived parameter...
952
		$res = $this->checkUser($obj);
10200969   Roipoussiere   Remove whitespace...
953

a0b3d64e   Benjamin Renard   Derived parameter...
954
955
		if (!$res['success'])
			return $res;
10200969   Roipoussiere   Remove whitespace...
956

a0b3d64e   Benjamin Renard   Derived parameter...
957
958
959
960
		IHMConfigClass::setUserName($this->user);
		$libParamPath = IHMConfigClass::getCompilationPath()."lib/".$obj->paramId.".so";
		if (file_exists($libParamPath))
			unlink($libParamPath);
735c653b   Elena.Budnik   rank at observato...
961
962
		return array("success" => true);
	}
10200969   Roipoussiere   Remove whitespace...
963

a0b3d64e   Benjamin Renard   Derived parameter...
964
/*
e6e5b259   Benjamin Renard   Add kill plot req...
965
 * kill plot process
16035364   Benjamin Renard   First commit
966
 */
10200969   Roipoussiere   Remove whitespace...
967

735c653b   Elena.Budnik   rank at observato...
968
	public function killPlotRequest()
10200969   Roipoussiere   Remove whitespace...
969
	{
735c653b   Elena.Budnik   rank at observato...
970
971
		return $this->executeRequest((object) array('nodeType' => 'killplot'), FunctionTypeEnumClass::PARAMS);
	}
16035364   Benjamin Renard   First commit
972
973
974
975

/*
 * merge time tables
 */
10200969   Roipoussiere   Remove whitespace...
976
	public  function merge($obj)
735c653b   Elena.Budnik   rank at observato...
977
978
979
	{
		if ($this->amdaStat->success)
			$this->amdaStat->addTask('ttoper', $this->user, null);
10200969   Roipoussiere   Remove whitespace...
980

735c653b   Elena.Budnik   rank at observato...
981
		$objectMgr = new TimeTableMgr();
16035364   Benjamin Renard   First commit
982

735c653b   Elena.Budnik   rank at observato...
983
984
		return  $objectMgr -> merge($obj);
	}
16035364   Benjamin Renard   First commit
985

10200969   Roipoussiere   Remove whitespace...
986

16035364   Benjamin Renard   First commit
987
988
989
/*
 * intersect time tables
 */
10200969   Roipoussiere   Remove whitespace...
990
	public  function intersect($obj)
735c653b   Elena.Budnik   rank at observato...
991
992
993
	{
		if ($this->amdaStat->success)
				$this->amdaStat->addTask('ttoper', $this->user, null);
16035364   Benjamin Renard   First commit
994

735c653b   Elena.Budnik   rank at observato...
995
996
		$objectMgr = new TimeTableMgr();
		$result = $objectMgr -> intersect($obj);
16035364   Benjamin Renard   First commit
997

735c653b   Elena.Budnik   rank at observato...
998
999
		return  $result;
	}
10200969   Roipoussiere   Remove whitespace...
1000

735c653b   Elena.Budnik   rank at observato...
1001
1002
1003
1004
	public function initTTCache($isCatalog = false, $nparams)
	{
		if (!$isCatalog) $cacheMgr = new TimeTableCacheMgr();
		else              $cacheMgr = new CatalogCacheMgr();
10200969   Roipoussiere   Remove whitespace...
1005

735c653b   Elena.Budnik   rank at observato...
1006
1007
		return $cacheMgr->initTTCache($nparams);
	}
10200969   Roipoussiere   Remove whitespace...
1008
1009


735c653b   Elena.Budnik   rank at observato...
1010
1011
1012
1013
	public function initTTCacheFromTT($id, $type)
	{
		if ($type == 'catalog' || $type == 'sharedcatalog') $cacheMgr = new CatalogCacheMgr();
		else $cacheMgr = new TimeTableCacheMgr();
10200969   Roipoussiere   Remove whitespace...
1014

735c653b   Elena.Budnik   rank at observato...
1015
1016
		return $cacheMgr->initFromTT($id, $type);
	}
10200969   Roipoussiere   Remove whitespace...
1017

735c653b   Elena.Budnik   rank at observato...
1018
1019
	public function initForChart($id, $name, $isTmpObject, $type)
	{
e1fd05b4   Elena.Budnik   visu from cacheCat
1020
1021
1022
		if ($isTmpObject && $type == 'catalog' && $id == 'cacheCat')
			return array('success' => true, 'cache' => $id);
			
735c653b   Elena.Budnik   rank at observato...
1023
		if ($type == 'catalog' || $type == 'sharedcatalog') $objMgr = new CatalogMgr();
10200969   Roipoussiere   Remove whitespace...
1024

735c653b   Elena.Budnik   rank at observato...
1025
1026
		return $objMgr->initForChart($id, $name, $isTmpObject, $type);
	}
10200969   Roipoussiere   Remove whitespace...
1027

735c653b   Elena.Budnik   rank at observato...
1028
1029
	public function initTTCacheFromTmpObject($folderId, $name, $isCatalog = false)
	{
10200969   Roipoussiere   Remove whitespace...
1030
		if (!$isCatalog) $cacheMgr = new TimeTableCacheMgr();
735c653b   Elena.Budnik   rank at observato...
1031
1032
1033
1034
		else  $cacheMgr = new CatalogCacheMgr();

		return $cacheMgr->initFromTmpObject($folderId, $name);
	}
10200969   Roipoussiere   Remove whitespace...
1035

901ba3f3   Elena.Budnik   upload catalog
1036
	public function initTTCacheFromUploadedFile($name, $format, $isCatalog = false)
735c653b   Elena.Budnik   rank at observato...
1037
	{
901ba3f3   Elena.Budnik   upload catalog
1038
1039
		if (!$isCatalog) $cacheMgr = new TimeTableCacheMgr();
		else  $cacheMgr = new CatalogCacheMgr();
10200969   Roipoussiere   Remove whitespace...
1040

735c653b   Elena.Budnik   rank at observato...
1041
1042
		return $cacheMgr->initFromUploadedFile($name, $format);
	}
10200969   Roipoussiere   Remove whitespace...
1043

735c653b   Elena.Budnik   rank at observato...
1044
1045
	public function readTTCacheIntervals($o)
	{
e57cb025   Benjamin Renard   Fix most of error...
1046
		if (isset($o->typeTT) && ($o->typeTT == 'catalog' || $o->typeTT == 'sharedcatalog')) $cacheMgr = new CatalogCacheMgr();
735c653b   Elena.Budnik   rank at observato...
1047
		else $cacheMgr = new TimeTableCacheMgr();
10200969   Roipoussiere   Remove whitespace...
1048

e57cb025   Benjamin Renard   Fix most of error...
1049
		return $cacheMgr->getIntervals($o->start,$o->limit,isset($o->sort) ? $o->sort : NULL, isset($o->filter) ? $o->filter : NULL);
735c653b   Elena.Budnik   rank at observato...
1050
	}
10200969   Roipoussiere   Remove whitespace...
1051

735c653b   Elena.Budnik   rank at observato...
1052
1053
	public function readIntervalsForChart($o)
	{
e57cb025   Benjamin Renard   Fix most of error...
1054
		if (isset($o->typeTT) && ($o->typeTT == 'catalog' || $o->typeTT == 'sharedcatalog')) {
e1fd05b4   Elena.Budnik   visu from cacheCat
1055
1056
1057
1058
1059
1060
1061
1062
1063
				
				if ($o->fromPlugin && $o->id == 'cacheCat') {
					$objMgr = new CatalogCacheMgr();
					
					return $objMgr->getIntervals();
				}
				
				$objMgr = new CatalogMgr();
		}
10200969   Roipoussiere   Remove whitespace...
1064

735c653b   Elena.Budnik   rank at observato...
1065
1066
		return $objMgr->getIntervalsForChart($o->id, $o->name, $o->fromPlugin, $o->typeTT);
	}
10200969   Roipoussiere   Remove whitespace...
1067

735c653b   Elena.Budnik   rank at observato...
1068
1069
1070
1071
1072
	public function saveTTCacheIntervalsInTT($o)
	{
		$cacheMgr = new TimeTableCacheMgr();
		return $cacheMgr->saveInTT($o->ttId,$o->action,$o->cacheToken);
	}
10200969   Roipoussiere   Remove whitespace...
1073

735c653b   Elena.Budnik   rank at observato...
1074
1075
1076
1077
1078
1079
1080
	public function addTTCacheInterval($o)
	{
		if ($o->isCatalog) $cacheMgr = new CatalogCacheMgr();
		else $cacheMgr = new TimeTableCacheMgr();

		return $cacheMgr->addInterval($o->index, $o->start, $o->stop);
	}
10200969   Roipoussiere   Remove whitespace...
1081

735c653b   Elena.Budnik   rank at observato...
1082
1083
1084
1085
1086
1087
1088
	public function removeTTCacheIntervalFromId($id, $isCatalog = false)
	{
		if ($isCatalog) $cacheMgr = new CatalogCacheMgr();
		else $cacheMgr = new TimeTableCacheMgr();

		return $cacheMgr->removeIntervalFromId($id);
	}
10200969   Roipoussiere   Remove whitespace...
1089

735c653b   Elena.Budnik   rank at observato...
1090
1091
	public function modifyTTCacheInterval($o)
	{
10200969   Roipoussiere   Remove whitespace...
1092
		if ($o->isCatalog)
735c653b   Elena.Budnik   rank at observato...
1093
		{
f9c8b272   elena   edit catalog
1094
			$cacheMgr = new CatalogCacheMgr();
735c653b   Elena.Budnik   rank at observato...
1095
			return $cacheMgr->modifyIntervalFromId($o);
f9c8b272   elena   edit catalog
1096
		}
735c653b   Elena.Budnik   rank at observato...
1097
		else $cacheMgr = new TimeTableCacheMgr();
10200969   Roipoussiere   Remove whitespace...
1098

735c653b   Elena.Budnik   rank at observato...
1099
1100
		return $cacheMgr->modifyIntervalFromId($o->cacheId, $o->start, $o->stop);
	}
10200969   Roipoussiere   Remove whitespace...
1101

735c653b   Elena.Budnik   rank at observato...
1102
1103
1104
1105
1106
	public function operationTTCacheIntervals($extendTime, $shiftTime)
	{
		$cacheMgr = new TimeTableCacheMgr();
		return $cacheMgr->operationIntervals($extendTime, $shiftTime);
	}
10200969   Roipoussiere   Remove whitespace...
1107

735c653b   Elena.Budnik   rank at observato...
1108
1109
1110
1111
1112
	public function mergeTTCacheIntervals()
	{
		$cacheMgr = new TimeTableCacheMgr();
		return $cacheMgr->mergeIntervals();
	}
10200969   Roipoussiere   Remove whitespace...
1113

735c653b   Elena.Budnik   rank at observato...
1114
1115
1116
1117
1118
	public function getTTCacheStatistics()
	{
		$cacheMgr = new TimeTableCacheMgr();
		return $cacheMgr->getStatistics();
	}
10200969   Roipoussiere   Remove whitespace...
1119

735c653b   Elena.Budnik   rank at observato...
1120
1121
1122
1123
1124
	public function getTTCacheStatus()
	{
		$cacheMgr = new TimeTableCacheMgr();
		return $cacheMgr->getStatus();
	}
aa94fd24   elena   Merge with last svn
1125

16035364   Benjamin Renard   First commit
1126
1127
/*
 * Send a feedback
10200969   Roipoussiere   Remove whitespace...
1128
 *
16035364   Benjamin Renard   First commit
1129
 */
735c653b   Elena.Budnik   rank at observato...
1130
1131
1132
1133
1134
	public function sendFeedback($feed)
	{
		$feedMgr = new FeedbackMgr();
		return $feedMgr->addFeedback($feed->user, $feed->interface, $feed->subject, $feed->userText, $feed->userAgent, $feed->attach);
	}
10200969   Roipoussiere   Remove whitespace...
1135

16035364   Benjamin Renard   First commit
1136
1137
/*
 * Save state
10200969   Roipoussiere   Remove whitespace...
1138
 *
16035364   Benjamin Renard   First commit
1139
 */
735c653b   Elena.Budnik   rank at observato...
1140
1141
1142
1143
1144
	public function saveState($datas)
	{
		$myStateMgr = new StateMgr();
		return $myStateMgr->saveState($datas);
	}
10200969   Roipoussiere   Remove whitespace...
1145

16035364   Benjamin Renard   First commit
1146
1147
/*
 * Load state
10200969   Roipoussiere   Remove whitespace...
1148
1149
 *
 */
735c653b   Elena.Budnik   rank at observato...
1150
	public function loadState($o)
10200969   Roipoussiere   Remove whitespace...
1151
	{
735c653b   Elena.Budnik   rank at observato...
1152
1153
1154
		$myStateMgr = new StateMgr();
		return $myStateMgr->loadState();
	}
10200969   Roipoussiere   Remove whitespace...
1155
1156

/*
16035364   Benjamin Renard   First commit
1157
1158
 * HST Images
 */
735c653b   Elena.Budnik   rank at observato...
1159
1160
1161
1162
	public function getHstImagesUrl($o)
	{
		if ($this->amdaStat->success)
			$this->amdaStat->addTask('images', $this->user, null);
10200969   Roipoussiere   Remove whitespace...
1163

735c653b   Elena.Budnik   rank at observato...
1164
1165
1166
1167
1168
1169
		$myHstMgr = new HstMgr();
		$res = $myHstMgr->getImagesUrl($o->startTime, $o->stopTime, $o->planet);
		//if ($domRes->length <= 0)
		//	return array('success' => false, 'message' => 'Cannot find HST Images for this request.');
		return array('success' => true, 'result' => $res);
	}
10200969   Roipoussiere   Remove whitespace...
1170

735c653b   Elena.Budnik   rank at observato...
1171
1172
	public function getAPISImagesUrl($o)
	{
10200969   Roipoussiere   Remove whitespace...
1173
		if ($this->amdaStat->success)
735c653b   Elena.Budnik   rank at observato...
1174
			$this->amdaStat->addTask('images', $this->user, null);
10200969   Roipoussiere   Remove whitespace...
1175

735c653b   Elena.Budnik   rank at observato...
1176
1177
1178
1179
		$apisMgr = new APISMgr();
		$res = $apisMgr->get($o->target, $o->startTime, $o->stopTime, $o->datasets);

		return $res;
10200969   Roipoussiere   Remove whitespace...
1180
	}
16035364   Benjamin Renard   First commit
1181
1182
1183
/*
 * Filters
 */
e57cb025   Benjamin Renard   Fix most of error...
1184
	public function loadFilterList()
735c653b   Elena.Budnik   rank at observato...
1185
	{
10200969   Roipoussiere   Remove whitespace...
1186
		$filtersMgr = new FiltersMgr();
735c653b   Elena.Budnik   rank at observato...
1187
1188
1189
		$res = $filtersMgr->loadList();
		return $res;
	}
16035364   Benjamin Renard   First commit
1190

735c653b   Elena.Budnik   rank at observato...
1191
1192
1193
1194
1195
1196
1197
1198
1199
	public function loadFilters($o)
	{
		$filtersMgr = new FiltersMgr();
		if (isset($o->id))
			$res = $filtersMgr->loadFilter($o->id);
		else
			$res = $filtersMgr->loadAll();
		return $res;
	}
10200969   Roipoussiere   Remove whitespace...
1200

735c653b   Elena.Budnik   rank at observato...
1201
1202
	public function saveFilter($o)
	{
10200969   Roipoussiere   Remove whitespace...
1203
		$filtersMgr = new FiltersMgr();
735c653b   Elena.Budnik   rank at observato...
1204
1205
		return $filtersMgr->save($o);
	}
10200969   Roipoussiere   Remove whitespace...
1206

735c653b   Elena.Budnik   rank at observato...
1207
1208
	public function createFilter($o)
	{
10200969   Roipoussiere   Remove whitespace...
1209
		$filtersMgr = new FiltersMgr();
735c653b   Elena.Budnik   rank at observato...
1210
1211
		return $filtersMgr->create($o);
	}
10200969   Roipoussiere   Remove whitespace...
1212

735c653b   Elena.Budnik   rank at observato...
1213
1214
1215
1216
1217
1218
	public function destroyFilter($o)
	{
		$filtersMgr = new FiltersMgr();
		$res = $filtersMgr->delete($o);
		return;
	}
10200969   Roipoussiere   Remove whitespace...
1219

735c653b   Elena.Budnik   rank at observato...
1220
1221
1222
1223
1224
1225
1226
	public function getCrtFilterId()
	{
		$filtersMgr = new FiltersMgr();
		$res = $filtersMgr->getCrtId();
		return $res;
	}

fdf1413b   Elena.Budnik   TT download
1227
1228
	public function getCrtFilterResult()
	{
10200969   Roipoussiere   Remove whitespace...
1229
		$filtersMgr = new FiltersMgr();
fdf1413b   Elena.Budnik   TT download
1230
1231
		return $filtersMgr->getCrtResult();
	}
10200969   Roipoussiere   Remove whitespace...
1232

fdf1413b   Elena.Budnik   TT download
1233
1234
	public function setCrtFilterId($o)
	{
10200969   Roipoussiere   Remove whitespace...
1235
		$filtersMgr = new FiltersMgr();
fdf1413b   Elena.Budnik   TT download
1236
1237
		return $filtersMgr->setCrtId($o->id);
	}
10200969   Roipoussiere   Remove whitespace...
1238

fdf1413b   Elena.Budnik   TT download
1239
1240
1241
1242
1243
1244
	public function resetFilter()
	{
		$filtersMgr = new FiltersMgr();
		$res = $filtersMgr->reset();
		return $res;
	}
10200969   Roipoussiere   Remove whitespace...
1245

16035364   Benjamin Renard   First commit
1246
1247
	public function logout($isGuest)
	{
10200969   Roipoussiere   Remove whitespace...
1248
		if ($isGuest)
735c653b   Elena.Budnik   rank at observato...
1249
		{
fdf1413b   Elena.Budnik   TT download
1250
1251
1252
			$guestMgr = new Guest($this->user);
			$guestMgr->deleteGuest();
		}
10200969   Roipoussiere   Remove whitespace...
1253
		else
735c653b   Elena.Budnik   rank at observato...
1254
		{
fdf1413b   Elena.Budnik   TT download
1255
			$this->cleanUserWS();
10200969   Roipoussiere   Remove whitespace...
1256
		}
16035364   Benjamin Renard   First commit
1257
		return;
10200969   Roipoussiere   Remove whitespace...
1258
	}
16035364   Benjamin Renard   First commit
1259

fdf1413b   Elena.Budnik   TT download
1260
1261
	public function getInfo($obj)
	{
10200969   Roipoussiere   Remove whitespace...
1262
		if (file_exists(HELPPATH.$obj->name))
fdf1413b   Elena.Budnik   TT download
1263
		{
10200969   Roipoussiere   Remove whitespace...
1264
			$content = file_get_contents(HELPPATH.$obj->name);
fdf1413b   Elena.Budnik   TT download
1265
1266
			return  array('success' => true, 'result' => $content);
		}
10200969   Roipoussiere   Remove whitespace...
1267
1268
1269
		return array('success' => false);
	}

fdf1413b   Elena.Budnik   TT download
1270
1271
1272
1273
1274
	public function getUserInfo()
	{
		$dd = new UserMgr();
		return $dd->getUserInfo();
	}
16035364   Benjamin Renard   First commit
1275

fdf1413b   Elena.Budnik   TT download
1276
1277
1278
1279
1280
	public function convertWS()
	{
		$dd = new UserMgr();
		return $dd->convertWS();
	}
16035364   Benjamin Renard   First commit
1281

fdf1413b   Elena.Budnik   TT download
1282
1283
1284
1285
1286
1287
	// $obj ={"Object":"Earth","RunCount":"2",
	// "SW_Density_value":"10","SW_Density_weight":"1","SW_Density_scale":"7","SW_Temperature_value":"100", ....}
	public function getRun($obj)
	{
		$myBestRunsMgr = new BestRunsMgr();
		$res = $myBestRunsMgr->getRun($obj);
10200969   Roipoussiere   Remove whitespace...
1288
1289

		return  $res;
fdf1413b   Elena.Budnik   TT download
1290
	}
10200969   Roipoussiere   Remove whitespace...
1291
1292

	//$obj = array of IDs
fdf1413b   Elena.Budnik   TT download
1293
1294
1295
	public function addRun($obj)
	{
		$myBestRunsMgr = new BestRunsMgr();
10200969   Roipoussiere   Remove whitespace...
1296

bf74fc2d   Elena.Budnik   IMPEX
1297
		$ok = $myBestRunsMgr->init();
10200969   Roipoussiere   Remove whitespace...
1298

bf74fc2d   Elena.Budnik   IMPEX
1299
1300
		if (!$ok)
			return array('success'=>false,'message'=>'cannot init addRun');
10200969   Roipoussiere   Remove whitespace...
1301

fdf1413b   Elena.Budnik   TT download
1302
		$myBestRunsMgr->addRuns($obj);
10200969   Roipoussiere   Remove whitespace...
1303

bf74fc2d   Elena.Budnik   IMPEX
1304
		return array('success'=>true,'addedRuns'=>$obj);
10200969   Roipoussiere   Remove whitespace...
1305
1306
	}

fdf1413b   Elena.Budnik   TT download
1307
1308
1309
1310
	//AKKA - New action to clean user WS
	public function cleanUserWS()
	{
		$this->rrmdir(USERDIR.'DOWNLOAD.TEMP');
bf74fc2d   Elena.Budnik   IMPEX
1311
		IHMConfigClass::setUserName($this->user);
10200969   Roipoussiere   Remove whitespace...
1312
1313

		// delete impex params and data
bf74fc2d   Elena.Budnik   IMPEX
1314
1315
		$impexParamMgr = new ImpexParamManager();
		$impexParamMgr->deleteImpexStaff();
10200969   Roipoussiere   Remove whitespace...
1316

e57cb025   Benjamin Renard   Fix most of error...
1317
		$obj = (object) array();
fdf1413b   Elena.Budnik   TT download
1318
1319
		return $this->executeRequest($obj, FunctionTypeEnumClass::PROCESSCLEAN);
	}
10200969   Roipoussiere   Remove whitespace...
1320

fdf1413b   Elena.Budnik   TT download
1321
1322
1323
	public function rrmdir($dir){
		if (is_dir($dir)) {
			$objects = scandir($dir);
10200969   Roipoussiere   Remove whitespace...
1324
1325
			foreach ($objects as $object) { // Recursively delete a directory that is not empty and directorys in directory
				if ($object != "." && $object != "..") {  // If object isn't a directory recall recursively this function
fdf1413b   Elena.Budnik   TT download
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
					if (filetype($dir."/".$object) == "dir")
						$this->rrmdir($dir."/".$object);
					else
						unlink($dir."/".$object);
				}
			}
			reset($objects);
			rmdir($dir);
		}
	}

	public function deleteSpecialInfo($name)
	{
10200969   Roipoussiere   Remove whitespace...
1339
		if (file_exists(USERDIR.$name))
fdf1413b   Elena.Budnik   TT download
1340
1341
1342
					unlink(USERDIR.$name);
		return array('success' => true);
	}
10200969   Roipoussiere   Remove whitespace...
1343

fdf1413b   Elena.Budnik   TT download
1344
1345
	public function interactivePlot($obj, $multiPlotState)
	{
fdf1413b   Elena.Budnik   TT download
1346
1347
1348
1349
1350
1351
		$inputobj = (Object)array(
			'action' => $obj,
			'multiPlotState' => $multiPlotState
		);
		return $this->executeRequest($inputobj, FunctionTypeEnumClass::ACTION);
	}
10200969   Roipoussiere   Remove whitespace...
1352

735c653b   Elena.Budnik   rank at observato...
1353
1354
	public function getParamPlotInit($obj)
	{
bf74fc2d   Elena.Budnik   IMPEX
1355
1356
1357
1358
1359
		// IMPEX param
		if (preg_match("#^spase___IMPEX_#",$obj->paramId))
			$type = 'impex_plot_init';
		else
		   $type = 'plot_init';
10200969   Roipoussiere   Remove whitespace...
1360

735c653b   Elena.Budnik   rank at observato...
1361
1362
		$inputobj = (Object)array(
				'paramId' => $obj->paramId,
bf74fc2d   Elena.Budnik   IMPEX
1363
				'type' => $type
735c653b   Elena.Budnik   rank at observato...
1364
1365
1366
		);
		return $this->executeRequest($inputobj, FunctionTypeEnumClass::PARAMINFO);
	}
10200969   Roipoussiere   Remove whitespace...
1367

735c653b   Elena.Budnik   rank at observato...
1368
1369
	public function getParamInfo($obj)
	{
bf74fc2d   Elena.Budnik   IMPEX
1370
1371
1372
1373
1374
		// IMPEX param
		if (preg_match("#^spase___IMPEX_#",$obj->paramId))
			$type = 'impex_param_info';
		else
		   $type = 'param_info';
10200969   Roipoussiere   Remove whitespace...
1375

735c653b   Elena.Budnik   rank at observato...
1376
1377
		$inputobj = (Object)array(
				'paramId' => $obj->paramId,
bf74fc2d   Elena.Budnik   IMPEX
1378
				'type' => $type
735c653b   Elena.Budnik   rank at observato...
1379
1380
1381
		);
		return $this->executeRequest($inputobj, FunctionTypeEnumClass::PARAMINFO);
	}
10200969   Roipoussiere   Remove whitespace...
1382

735c653b   Elena.Budnik   rank at observato...
1383
1384
1385
1386
1387
1388
	public function getSharedObjectFolders($obj)
	{
		$mgr = new SharedObjectsMgr();
		$folders = $mgr->getFolders($obj->type);
		return array('success' => true, 'folders' => $folders);
	}
10200969   Roipoussiere   Remove whitespace...
1389

735c653b   Elena.Budnik   rank at observato...
1390
1391
1392
	public function shareObjects($obj)
	{
		$mgr = new SharedObjectsMgr();
10200969   Roipoussiere   Remove whitespace...
1393
		switch ($obj->type)
735c653b   Elena.Budnik   rank at observato...
1394
1395
1396
1397
1398
		{
			case 'timeTable' :
			case 'catalog' :
				$src_object_path = USERTTDIR.$obj->object->id.".xml";
				break;
10200969   Roipoussiere   Remove whitespace...
1399

735c653b   Elena.Budnik   rank at observato...
1400
1401
1402
			default:
				return array('success' => false, 'message' => 'Unknown object type');
		}
10200969   Roipoussiere   Remove whitespace...
1403

735c653b   Elena.Budnik   rank at observato...
1404
1405
1406
		$result = $mgr->add($obj->type, $obj->name, $obj->folder, $src_object_path, $obj->description, $this->user);
		if (!$result['success'])
			return $result;
10200969   Roipoussiere   Remove whitespace...
1407

735c653b   Elena.Budnik   rank at observato...
1408
1409
1410
		$mgr->updateTree();
		return $result;
	}
10200969   Roipoussiere   Remove whitespace...
1411

735c653b   Elena.Budnik   rank at observato...
1412
1413
1414
1415
1416
1417
	public function isSharedObjectNameAlreadyUsed($obj)
	{
		$mgr = new SharedObjectsMgr();
		$alreadyUsed = $mgr->isNameAlreadyUsed($obj->type, $obj->name);
		return array('success' => true, 'alreadyUsed' => $alreadyUsed);
	}
10200969   Roipoussiere   Remove whitespace...
1418

0bda97f3   Benjamin Renard   Fix SAMP export f...
1419
1420
	public function getRequestByProcessId($obj)
	{
0bda97f3   Benjamin Renard   Fix SAMP export f...
1421
1422
		return $this->executeRequest($obj->processId, FunctionTypeEnumClass::PROCESSGETREQUEST);
	}
16035364   Benjamin Renard   First commit
1423
1424
}
?>