WfsJsRequestPanel.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  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'] = [
  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>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  40. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  41. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  42. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  43. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  44. ];
  45. $listExampleProp['lvl2wsk'] = [
  46. " <wfs:PropertyName>ID</wfs:PropertyName>",
  47. " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
  48. " <wfs:PropertyName>TYPE</wfs:PropertyName>",
  49. " <wfs:PropertyName>DESC</wfs:PropertyName>",
  50. " <wfs:PropertyName>OPIS</wfs:PropertyName>",
  51. " <wfs:PropertyName>path</wfs:PropertyName>",
  52. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  53. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  54. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  55. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  56. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  57. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK</wfs:PropertyName>",
  58. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/*</wfs:PropertyName>",
  59. " <!-- <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/**</wfs:PropertyName> -->",
  60. " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  61. ];
  62. $listExampleProp['lvl3'] = [
  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>OPIS</wfs:PropertyName>",
  68. " <wfs:PropertyName>path</wfs:PropertyName>",
  69. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  70. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  71. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  72. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  73. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
  74. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
  75. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
  76. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
  77. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
  78. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  79. " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/*</wfs:PropertyName>",
  80. " <!-- <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES_INIT/**</wfs:PropertyName> -->",
  81. " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
  82. ];
  83. $exampleWfsRequestBody = "<wfs:Query>" . implode("\n", array_merge($listExampleProp['lvl1'], $exampleFltr)) . "</wfs:Query>";
  84. UI::startContainer();
  85. // Lib::loadClass('Vendor_Monolog');
  86. // $logger = new Vendor_Monolog('dbg-logger-name');
  87. // $logger->pushHandler(new StreamHandler('/tmp/monolog-test.log', Vendor_Monolog::WARNING));
  88. // $logger->warning('Foo');
  89. // $logger->error('Bar');
  90. //
  91. // $logFile = '/tmp/monolog-test-json.log';
  92. // $formatter = new JsonFormatter();
  93. // // Create a handler
  94. // $stream = new StreamHandler($logFile, Vendor_Monolog::INFO);
  95. // $stream->setFormatter($formatter);
  96. // // bind it to a logger object
  97. // $securityLogger = new Vendor_Monolog('View Info');
  98. // $securityLogger->pushHandler($stream);
  99. // $securityLogger->addInfo('debug message / label', [ 'dbg-object' => [ 'x' => 'y', 'z' ] ]);
  100. echo UI::h('textarea', [ 'id' => 'wfsRequestBody', 'style' => "width:100%; height:300px" ], htmlspecialchars($exampleWfsRequestBody));
  101. echo UI::h('button', [ 'class' => "btn btn-primary", 'onClick' => "return sendWfsRequest(this)" ], "Wyslij");
  102. echo UI::h('div', [ 'style' => "display:inline", 'id' => "wfs-example-btns" ]);
  103. echo UI::h('details', [ 'style' => "padding:6px; background-color:#333; color:#fff", 'open' => "open" ], [
  104. UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], "WFS Response"),
  105. UI::h('pre', [ 'id' => 'wfsResponse', 'style' => "margin:0; font-size:x-small; border-radius:0" ], 'loading...'),
  106. ]);
  107. echo UI::h('details', [ 'style' => "padding:6px; background-color:#68cbfd; color:#fff" ], [
  108. UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], [
  109. UI::h('i',[ 'class' => "glyphicon glyphicon-question-sign" ]),
  110. " WFS 1.1, 2.0 fetch nested objects (traverse, resolve)",
  111. ]),
  112. UI::h('pre', ['style' => "margin:0; font-size:x-small; border-radius:0"], implode("\n", [
  113. "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"),
  114. "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"),
  115. "",
  116. "WFS 1.1 traverseXlinkDepth type=\"string\" ('*' or int > 0) - recurse limit ('*' - no limit)",
  117. "WFS 1.1 traverseXlinkExpiry type=\"xsd:positiveInteger\" - timeOut in minutes",
  118. "WFS 1.1 Note: traverse used in wfs:GetFeature or inside wfs:Query tag wfs:XlinkPropertyName (same like wfs:PropertyName but with @traverse* attributes)",
  119. "",
  120. "WFS 2.0 resolve type=\"wfs:ResolveValueType\" default=\"none\" (enum: 'local', 'remote', 'all', 'none')",
  121. " - resolve=\"local\" - operation shall only resolve local references",
  122. " - resolve=\"remote\" - operation shall only resolve remote resource references",
  123. " - resolve=\"all\" - means that an operation shall resolve all resource references",
  124. " - resolve=\"none\" - means that an operation shall not resolve any resource references",
  125. "WFS 2.0 resolveDepth type=\"wfs:positiveIntegerWithStar\" default=\"*\" ('*' or int > 0) - recurse limit ('*' - no limit)",
  126. "WFW 2.0 resolveTimeout type=\"xsd:positiveInteger\" default=\"300\" - timeOut in seconds",
  127. "WFS 2.0 Note: resolve used in wfs:GetFeature or inside wfs:Query tag wfs:PropertyName",
  128. " 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"),
  129. "",
  130. "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"),
  131. ])),
  132. ]);
  133. UI::endContainer();
  134. $examples = array_map(function ($props) use ($exampleFltr) {
  135. return "<wfs:Query>" . implode("\n", array_merge($props, $exampleFltr)) . "</wfs:Query>";
  136. }, $listExampleProp);
  137. echo UI::h('script', [], "
  138. var examples = " . json_encode($examples) . ";
  139. console.log('examples', examples)
  140. function setWfsExample(i) {
  141. document.getElementById('wfsRequestBody').value = examples[i]
  142. sendWfsRequest()
  143. }
  144. for (var i in examples) {
  145. jQuery(document.getElementById('wfs-example-btns')).append('<button class=\"btn btn-default\" style=\"margin-left:12px\" onClick=\"setWfsExample(\''+i+'\')\">'+i+'</button>')
  146. }
  147. ");
  148. echo UI::h('script', [], "
  149. function sendWfsRequest() {
  150. document.getElementById('wfsResponse').innerHTML = 'loading...'
  151. var postBody = document.getElementById('wfsRequestBody').value.replace(/&lt;/g, '<').replace(/&gt;/g, '>')
  152. console.log('wfsRequestBody:', postBody)
  153. p5WFS_GetFeature('default_db__x3A__CRM_PROCES:PROCES', {
  154. 'ogc:Filter': postBody,
  155. }).then(function (features) {
  156. console.log('features', features)
  157. document.getElementById('wfsResponse').innerHTML = JSON.stringify(features, null, 2)
  158. }).catch(function (e) {
  159. console.warn(e)
  160. document.getElementById('wfsResponse').innerHTML = JSON.stringify(e, null, 2)
  161. p5UI__notifyAjaxCallback({ type: 'error', msg: e })
  162. })
  163. return false
  164. }
  165. (function () {
  166. console.log('p5WFS_GetFeature(default_db__x3A__CRM_PROCES:PROCES, ...)')
  167. sendWfsRequest()
  168. })()
  169. ");
  170. } catch (Exception $e) {
  171. UI::alert('danger', $e);
  172. }
  173. UI::dol();
  174. }
  175. }