WfsJsRequestPanel.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <?php
  2. // use Monolog\Handler\StreamHandler;
  3. // use Monolog\Formatter\JsonFormatter;
  4. Lib::loadClass('RouteBase');
  5. Lib::loadClass('P5');
  6. Lib::loadClass('Core_AclHelper');
  7. Lib::loadClass('ACL');
  8. class Route_WfsJsRequestPanel extends RouteBase {
  9. public function defaultAction() {
  10. UI::gora();
  11. try {
  12. $exampleFltr = [
  13. " <ogc:Filter>",
  14. " <ogc:Or>",
  15. " <ogc:PropertyIsEqualTo>",
  16. " <ogc:PropertyName>ID</ogc:PropertyName>",
  17. " <ogc:Literal>1003</ogc:Literal>",
  18. " </ogc:PropertyIsEqualTo>",
  19. " <ogc:PropertyIsEqualTo>",
  20. " <ogc:PropertyName>ID</ogc:PropertyName>",
  21. " <ogc:Literal>608</ogc:Literal>",
  22. " </ogc:PropertyIsEqualTo>",
  23. " </ogc:Or>",
  24. " </ogc:Filter>",
  25. ];
  26. $listExampleProp = [];
  27. $listExampleProp['lvl1'] = [
  28. " <wfs:PropertyName>ID</wfs:PropertyName>",
  29. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  30. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  31. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  32. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  33. ];
  34. $listExampleProp['lvl2-by-@-1'] = [
  35. " <wfs:PropertyName>ID</wfs:PropertyName>",
  36. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  37. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  38. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  39. " <wfs:PropertyName resolve=\"all\" resolveDepth=\"1\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  40. ];
  41. $listExampleProp['lvl2-by-@-2'] = [
  42. " <wfs:PropertyName>ID</wfs:PropertyName>",
  43. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  44. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  45. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  46. " <wfs:PropertyName resolve=\"all\" resolveDepth=\"2\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  47. ];
  48. $listExampleProp['lvl2-by-@-3'] = [
  49. " <wfs:PropertyName>ID</wfs:PropertyName>",
  50. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  51. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  52. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  53. " <wfs:PropertyName resolve=\"all\" resolveDepth=\"3\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  54. ];
  55. $listExampleProp['lvl2-by-@-*'] = [
  56. " <wfs:PropertyName>ID</wfs:PropertyName>",
  57. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  58. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  59. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  60. " <wfs:PropertyName resolve=\"all\" resolveDepth=\"*\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  61. ];
  62. $listExampleProp['lvl2'] = [
  63. " <wfs:PropertyName>ID</wfs:PropertyName>",
  64. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  65. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  66. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  67. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  68. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  69. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  70. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  71. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  72. ];
  73. $listExampleProp['lvl2wsk'] = [
  74. " <wfs:PropertyName>ID</wfs:PropertyName>",
  75. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  76. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  77. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  78. " <wfs:PropertyName>OPIS</wfs:PropertyName>",
  79. " <wfs:PropertyName>path</wfs:PropertyName>",
  80. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  81. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  82. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  83. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  84. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  85. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK</wfs:PropertyName>",
  86. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/*</wfs:PropertyName>",
  87. " <!-- <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/**</wfs:PropertyName> -->",
  88. " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  89. ];
  90. $listExampleProp['lvl3'] = [
  91. " <wfs:PropertyName>ID</wfs:PropertyName>",
  92. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  93. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  94. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  95. " <wfs:PropertyName>OPIS</wfs:PropertyName>",
  96. " <wfs:PropertyName>path</wfs:PropertyName>",
  97. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  98. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  99. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  100. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  101. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  102. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  103. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  104. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  105. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  106. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  107. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/*</wfs:PropertyName>",
  108. " <!-- <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/**</wfs:PropertyName> -->",
  109. " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  110. ];
  111. $exampleWfsRequestBody = "<wfs:Query>" . "\n" . implode("\n", array_merge($listExampleProp['lvl1'], $exampleFltr)) . "\n" ."</wfs:Query>";
  112. UI::startContainer();
  113. // Lib::loadClass('Vendor_Monolog');
  114. // $logger = new Vendor_Monolog('dbg-logger-name');
  115. // $logger->pushHandler(new StreamHandler('/tmp/monolog-test.log', Vendor_Monolog::WARNING));
  116. // $logger->warning('Foo');
  117. // $logger->error('Bar');
  118. //
  119. // $logFile = '/tmp/monolog-test-json.log';
  120. // $formatter = new JsonFormatter();
  121. // // Create a handler
  122. // $stream = new StreamHandler($logFile, Vendor_Monolog::INFO);
  123. // $stream->setFormatter($formatter);
  124. // // bind it to a logger object
  125. // $securityLogger = new Vendor_Monolog('View Info');
  126. // $securityLogger->pushHandler($stream);
  127. // $securityLogger->addInfo('debug message / label', [ 'dbg-object' => [ 'x' => 'y', 'z' ] ]);
  128. echo UI::h('textarea', [ 'id' => 'wfsRequestBody', 'style' => "width:100%; height:300px" ], htmlspecialchars($exampleWfsRequestBody));
  129. echo UI::h('button', [ 'class' => "btn btn-primary", 'onClick' => "return sendWfsRequest(this)" ], "Wyslij");
  130. echo UI::h('div', [ 'style' => "display:inline", 'id' => "wfs-example-btns" ]);
  131. echo UI::h('details', [ 'style' => "padding:6px; background-color:#333; color:#fff", 'open' => "open" ], [
  132. UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], "WFS Response converted to JSON"),
  133. UI::h('pre', [ 'id' => 'wfsResponse', 'style' => "margin:0; font-size:x-small; border-radius:0" ], 'loading...'),
  134. ]);
  135. echo UI::h('details', [ 'style' => "padding:6px; background-color:#68cbfd; color:#fff" ], [
  136. UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], [
  137. UI::h('i',[ 'class' => "glyphicon glyphicon-question-sign" ]),
  138. " WFS 1.1, 2.0 fetch nested objects (traverse, resolve)",
  139. ]),
  140. UI::h('pre', ['style' => "margin:0; font-size:x-small; border-radius:0"], implode("\n", [
  141. "WFS 1.1 - traverseXlinkDepth, traverseXlinkExpiry " . UI::h('a', ['href'=>"http://docs.opengeospatial.org/is/04-094r1/04-094r1.html#50"], "http://docs.opengeospatial.org/is/04-094r1/04-094r1.html#50"),
  142. "WFS 2.0 - resolve, resolveDepth, resolveTimeout " . UI::h('a', ['href'=>"http://docs.opengeospatial.org/is/09-025r2/09-025r2.html#57"], "http://docs.opengeospatial.org/is/09-025r2/09-025r2.html#57"),
  143. "",
  144. "WFS 1.1 traverseXlinkDepth type=\"string\" ('*' or int > 0) - recurse limit ('*' - no limit)",
  145. "WFS 1.1 traverseXlinkExpiry type=\"xsd:positiveInteger\" - timeOut in minutes",
  146. "WFS 1.1 Note: traverse used in wfs:GetFeature or inside wfs:Query tag wfs:XlinkPropertyName (same like wfs:PropertyName but with @traverse* attributes)",
  147. "",
  148. "WFS 2.0 resolve type=\"wfs:ResolveValueType\" default=\"none\" (enum: 'local', 'remote', 'all', 'none')",
  149. " - resolve=\"local\" - operation shall only resolve local references",
  150. " - resolve=\"remote\" - operation shall only resolve remote resource references",
  151. " - resolve=\"all\" - means that an operation shall resolve all resource references",
  152. " - resolve=\"none\" - means that an operation shall not resolve any resource references",
  153. "WFS 2.0 resolveDepth type=\"wfs:positiveIntegerWithStar\" default=\"*\" ('*' or int > 0) - recurse limit ('*' - no limit)",
  154. "WFW 2.0 resolveTimeout type=\"xsd:positiveInteger\" default=\"300\" - timeOut in seconds",
  155. "WFS 2.0 Note: resolve used in wfs:GetFeature or inside wfs:Query tag wfs:PropertyName",
  156. " in wfs:PropertyName may use resolvePath - @see " . UI::h('a', ['href'=>"http://docs.opengeospatial.org/is/09-025r2/09-025r2.html#103"], "http://docs.opengeospatial.org/is/09-025r2/09-025r2.html#103"),
  157. "",
  158. "WFS 2.0 resolve, resolveDepth example " . UI::h('a', ['href'=>"http://grepcode.com/file/repo1.maven.org/maven2/org.jvnet.ogc/ogc-schemas/2.2.0/ogc/wfs/2.0/examples/GetFeature/GetFeature_12.xml"], "http://grepcode.com/file/repo1.maven.org/maven2/org.jvnet.ogc/ogc-schemas/2.2.0/ogc/wfs/2.0/examples/GetFeature/GetFeature_12.xml"),
  159. ])),
  160. ]);
  161. UI::endContainer();
  162. $examples = array_map(function ($props) use ($exampleFltr) {
  163. return "<wfs:Query>" . "\n" . implode("\n", array_merge($props, $exampleFltr)) . "\n" . "</wfs:Query>";
  164. }, $listExampleProp);
  165. echo UI::h('script', [], "
  166. var examples = " . json_encode($examples) . ";
  167. console.log('examples', examples)
  168. function setWfsExample(i) {
  169. document.getElementById('wfsRequestBody').value = examples[i]
  170. sendWfsRequest()
  171. }
  172. for (var i in examples) {
  173. jQuery(document.getElementById('wfs-example-btns')).append('<button class=\"btn btn-default\" style=\"margin-left:12px\" onClick=\"setWfsExample(\''+i+'\')\">'+i+'</button>')
  174. }
  175. ");
  176. echo UI::h('script', [], "
  177. function sendWfsRequest() {
  178. document.getElementById('wfsResponse').innerHTML = 'loading...'
  179. var postBody = document.getElementById('wfsRequestBody').value.replace(/&lt;/g, '<').replace(/&gt;/g, '>')
  180. console.log('wfsRequestBody:', postBody)
  181. p5WFS_GetFeature('default_db__x3A__CRM_PROCES:PROCES', {
  182. 'ogc:Filter': postBody,
  183. }).then(function (features) {
  184. console.log('features', features)
  185. document.getElementById('wfsResponse').innerHTML = JSON.stringify(features, null, 2)
  186. }).catch(function (e) {
  187. console.warn(e)
  188. document.getElementById('wfsResponse').innerHTML = JSON.stringify(e, null, 2)
  189. p5UI__notifyAjaxCallback({ type: 'error', msg: e })
  190. })
  191. return false
  192. }
  193. (function () {
  194. console.log('p5WFS_GetFeature(default_db__x3A__CRM_PROCES:PROCES, ...)')
  195. sendWfsRequest()
  196. })()
  197. ");
  198. } catch (Exception $e) {
  199. UI::alert('danger', $e);
  200. }
  201. UI::dol();
  202. }
  203. }