setLogger($wfsLogger); $this->reqDBG($request); if (empty($request->segments)) { //$this->mainWpsAction($request);// show list of posible data source throw new HttpException("Bad Request", 400); } else { $pathPart = array_shift($request->segments); if ('filtr_proces_' == substr($pathPart, 0, 13)) { $this->_idFiltrProces = (int)substr($pathPart, 13); if (!$this->_idFiltrProces) throw new Api_WfsException("Wrong filtr process number"); $this->DBG("filtr procesu({$idProcesFiltr})", __LINE__, __FUNCTION__, __CLASS__); $pathPart = array_shift($request->segments); } $this->_dataSourceName = $pathPart; $this->DBG("dataSourceAction({$this->_dataSourceName}) ...", __LINE__); try { $this->dataSourceAction($request); } catch (Api_WfsException $e) { $e->sendResponseXml(); } catch (Exception $e) { $wfsException = new Api_WfsException($e->getMessage(), $e->getCode(), $e); $wfsException->sendResponseXml(); } $this->DBG("dataSourceAction() END", __LINE__); } exit; // return document tree - array of arrays } public function wfsServerAction($request) { } public function dataSourceAction($request) { $document = ''; //$userAcl = User::getAcl(); IF(V::get('DBG','',$_GET)){echo'
user (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($this->_apiUser);echo'
';} $userAcl = new UserAcl($this->_apiUser->getID(), $use_cache = true); $userAcl->fetchGroups(); if ($this->_idFiltrProces) { if (!$userAcl->canExecuteProcesInit($this->_idFiltrProces)) { throw new Api_WfsException("Access Denied for given process"); } $userAcl->fetchProcesPerms($this->_idFiltrProces, true); } else { $userAcl->fetchAllPerms(true); } IF(V::get('DBG','',$_GET)){echo'
$userAcl (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($userAcl);echo'
';} $this->DBG("usr:" . $this->_apiUser->getID(), __LINE__, __FUNCTION__, __CLASS__); $wfsServer = new Api_WfsDataServer($userAcl); $wfsServer->setBaseUri($this->_apiBaseUri); if ('WFS' != V::get('SERVICE', '', $request->query) and ('WFS' != V::get('service', '', $request->query))) { throw new Api_WfsException("Only WFS Service is allowed"); } $req = V::get('REQUEST', '', $request->query); if (!empty($req)) { $methodName = "{$req}Action"; if (!method_exists($wfsServer, $methodName)) { throw new Api_WfsException("Not Implemented " . htmlspecialchars($req), 501); } $this->DBG("WfsServer->{$methodName}() ...", __LINE__); $document = $wfsServer->$methodName($urlQuery); } else { $this->DBG("WfsServer->parseXMLRequest() ...", __LINE__); $document = $wfsServer->parseXMLRequest(); header('Content-type: application/xml'); echo ''; echo $document; exit;// TODO: return $document; } IF(V::get('DBG','',$_GET)){echo'
$document (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($document);echo'
';} if ('raw' == V::get('outputFormat', '', $request->query)) { header('Content-type: text/plain; charset=utf-8'); echo $document; } else { header('Content-type: application/xml'); echo $document; } exit;// TODO: return $document; } public function mainWpsAction($request) { return array('TODO:'=>'TODO: Show main WPS GetCapabilities'); } }