WfsNs.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. Lib::loadClass('Request');
  3. class Api_WfsNs {
  4. // @usage: Api_WfsNs::getNsList();
  5. public static function getNsList() {
  6. $listNs = array();
  7. $baseNsUri = self::getBaseWfsUri();
  8. $listNs["{$baseNsUri}"] = 'p5';
  9. $listNs["{$baseNsUri}/default_db"] = 'default_db';
  10. $listNs["{$baseNsUri}/default_objects"] = 'default_objects';
  11. $listNs["{$baseNsUri}/objects"] = 'p5_objects';// TODO: to remove
  12. return $listNs;
  13. }
  14. // @usage: Api_WfsNs::getNsUri('default_db');
  15. public static function getNsUri($nsPrefix) {
  16. $listNs = self::getNsList();
  17. $nsMap = array_flip($listNs);
  18. $nsUri = V::get($nsPrefix, null, $nsMap);
  19. if (!$nsUri) {
  20. if ('p5_default_db' == $nsPrefix) return V::get('default_db', null, $nsMap);
  21. if ('objects' == $nsPrefix) return V::get('p5_objects', null, $nsMap);
  22. if ('default_db__x3A__' == substr($nsPrefix, 0, 17)) return $nsMap['default_db'] . "/" . substr($nsPrefix, 17);
  23. }
  24. return $nsUri;
  25. }
  26. // @usage: Api_WfsNs::getNsPrefix('https://biuro.biall-net.pl/wfs/default_db');
  27. public static function getNsPrefix($nsUri) {
  28. $listNs = self::getNsList();
  29. $nsUri = trim($nsUri);
  30. $nsUri = rtrim($nsUri, '/');
  31. $prefix = V::get($nsUri, null, $listNs);
  32. if ($prefix) return $prefix;
  33. $relativeNsUri = ('http' == substr($nsUri, 0, 4))
  34. ? substr($nsUri, strlen(self::getBaseWfsUri()) + 1)
  35. : $nsUri;
  36. $prefix = V::get(self::getBaseWfsUri() . "/{$relativeNsUri}", null, $listNs);
  37. if ($prefix) return $prefix;
  38. if (false === strpos($nsUri, '/')) throw new Exception("BUG: Unsupported namespace uri '{$nsUri}'");
  39. $nsEx = explode("/", $relativeNsUri);
  40. if ('default_db' != $nsEx[0]) throw new Exception("BUG: Unsupported namespace uri '{$nsUri}'");
  41. return str_replace('/', '__x3A__', $relativeNsUri);
  42. }
  43. // @usage: Api_WfsNs::getBaseWfsUri();
  44. public static function getBaseWfsUri() {
  45. return Request::getHostUri() . "/wfs";
  46. }
  47. /**
  48. * @return [ $nsUri, $prefix, $name ]
  49. * @example: list($nsUri, $prefix, $name) = Api_WfsNs::parseObjectNsUri('default_objects/AccessOwner');
  50. */
  51. public static function parseObjectNsUri($objectNsUri) {
  52. if ('{' == substr($objectNsUri, 0, 1)) $objectNsUri = str_replace('}', '/', substr($objectNsUri, 1));// form like "{.../wfs/default_objects}AccessOwner"
  53. $nsEx = explode('/', $objectNsUri);
  54. $name = array_pop($nsEx);
  55. $nsUri = implode('/', $nsEx);
  56. if ('http' !== substr($nsUri, 0, 4)) $nsUri = self::getBaseWfsUri() . "/" . $nsUri;
  57. $prefix = self::getNsPrefix($nsUri);
  58. return [ $nsUri, $prefix, $name ];
  59. }
  60. }