| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 |
- <?php
- // use Monolog\Handler\StreamHandler;
- // use Monolog\Formatter\JsonFormatter;
- Lib::loadClass('RouteBase');
- Lib::loadClass('P5');
- Lib::loadClass('Core_AclHelper');
- Lib::loadClass('ACL');
- class Route_WfsJsRequestPanel extends RouteBase {
- public function defaultAction() {
- UI::gora();
- try {
- $exampleFltr = [
- " <ogc:Filter>",
- " <ogc:Or>",
- " <ogc:PropertyIsEqualTo>",
- " <ogc:PropertyName>ID</ogc:PropertyName>",
- " <ogc:Literal>1003</ogc:Literal>",
- " </ogc:PropertyIsEqualTo>",
- " <ogc:PropertyIsEqualTo>",
- " <ogc:PropertyName>ID</ogc:PropertyName>",
- " <ogc:Literal>608</ogc:Literal>",
- " </ogc:PropertyIsEqualTo>",
- " </ogc:Or>",
- " </ogc:Filter>",
- ];
- $listExampleProp = [];
- $listExampleProp['lvl1'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2-by-@-1'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName resolve=\"all\" resolveDepth=\"1\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2-by-@-2'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName resolve=\"all\" resolveDepth=\"2\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2-by-@-3'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName resolve=\"all\" resolveDepth=\"3\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2-by-@-*'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName resolve=\"all\" resolveDepth=\"*\">default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- ];
- $listExampleProp['lvl2wsk'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName>OPIS</wfs:PropertyName>",
- " <wfs:PropertyName>path</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
- ];
- $listExampleProp['lvl3'] = [
- " <wfs:PropertyName>ID</wfs:PropertyName>",
- " <wfs:PropertyName>PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>DESC</wfs:PropertyName>",
- " <wfs:PropertyName>OPIS</wfs:PropertyName>",
- " <wfs:PropertyName>path</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/PARENT_ID</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/TYPE</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/DESC</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_PROCES:PROCES</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_PROCES:PROCES/default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
- " <wfs:PropertyName>default_db__x3A__CRM_WSKAZNIK:CRM_WSKAZNIK/*</wfs:PropertyName>",
- ];
- $exampleWfsRequestBody = "<wfs:Query>" . "\n" . implode("\n", array_merge($listExampleProp['lvl1'], $exampleFltr)) . "\n" ."</wfs:Query>";
- UI::startContainer();
- // Lib::loadClass('Vendor_Monolog');
- // $logger = new Vendor_Monolog('dbg-logger-name');
- // $logger->pushHandler(new StreamHandler('/tmp/monolog-test.log', Vendor_Monolog::WARNING));
- // $logger->warning('Foo');
- // $logger->error('Bar');
- //
- // $logFile = '/tmp/monolog-test-json.log';
- // $formatter = new JsonFormatter();
- // // Create a handler
- // $stream = new StreamHandler($logFile, Vendor_Monolog::INFO);
- // $stream->setFormatter($formatter);
- // // bind it to a logger object
- // $securityLogger = new Vendor_Monolog('View Info');
- // $securityLogger->pushHandler($stream);
- // $securityLogger->addInfo('debug message / label', [ 'dbg-object' => [ 'x' => 'y', 'z' ] ]);
- // 'wfsRequestFeatureTypeName' = 'default_db__x3A__CRM_PROCES:PROCES'
- echo UI::h('input', [ 'id' => 'wfsRequestFeatureTypeName', 'class' => "form-control", 'value' => 'default_db__x3A__CRM_PROCES:PROCES', 'title' => "Feature name" ]);
- echo UI::h('textarea', [ 'id' => 'wfsRequestBody', 'style' => "width:100%; height:300px" ], htmlspecialchars($exampleWfsRequestBody));
- echo UI::h('button', [ 'class' => "btn btn-primary", 'onClick' => "return sendWfsRequest(this)" ], "Wyslij");
- echo UI::h('div', [ 'style' => "display:inline", 'id' => "wfs-example-btns" ]);
- echo UI::h('details', [ 'style' => "padding:6px; background-color:#333; color:#fff", 'open' => "open" ], [
- UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], "WFS Response converted to JSON"),
- UI::h('pre', [ 'id' => 'wfsResponse', 'style' => "margin:0; font-size:x-small; border-radius:0" ], 'loading...'),
- ]);
- echo UI::h('details', [ 'style' => "padding:6px; background-color:#68cbfd; color:#fff" ], [
- UI::h('summary', [ 'style' => "padding:0 3px; outline:none; cursor:pointer" ], [
- UI::h('i',[ 'class' => "glyphicon glyphicon-question-sign" ]),
- " WFS 1.1, 2.0 fetch nested objects (traverse, resolve)",
- ]),
- UI::h('pre', ['style' => "margin:0; font-size:x-small; border-radius:0"], implode("\n", [
- "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"),
- "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"),
- "",
- "WFS 1.1 traverseXlinkDepth type=\"string\" ('*' or int > 0) - recurse limit ('*' - no limit)",
- "WFS 1.1 traverseXlinkExpiry type=\"xsd:positiveInteger\" - timeOut in minutes",
- "WFS 1.1 Note: traverse used in wfs:GetFeature or inside wfs:Query tag wfs:XlinkPropertyName (same like wfs:PropertyName but with @traverse* attributes)",
- "",
- "WFS 2.0 resolve type=\"wfs:ResolveValueType\" default=\"none\" (enum: 'local', 'remote', 'all', 'none')",
- " - resolve=\"local\" - operation shall only resolve local references",
- " - resolve=\"remote\" - operation shall only resolve remote resource references",
- " - resolve=\"all\" - means that an operation shall resolve all resource references",
- " - resolve=\"none\" - means that an operation shall not resolve any resource references",
- "WFS 2.0 resolveDepth type=\"wfs:positiveIntegerWithStar\" default=\"*\" ('*' or int > 0) - recurse limit ('*' - no limit)",
- "WFW 2.0 resolveTimeout type=\"xsd:positiveInteger\" default=\"300\" - timeOut in seconds",
- "WFS 2.0 Note: resolve used in wfs:GetFeature or inside wfs:Query tag wfs:PropertyName",
- " 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"),
- "",
- "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"),
- ])),
- ]);
- UI::endContainer();
- $examples['Procesy'] = [
- 'typeName' => 'default_db__x3A__CRM_PROCES:PROCES',
- 'examples' => array_map(function ($props) use ($exampleFltr) {
- return "<wfs:Query>" . "\n" . implode("\n", array_merge($props, $exampleFltr)) . "\n" . "</wfs:Query>";
- }, $listExampleProp),
- ];
- $examples['BiAudit'] = [
- 'typeName' => 'default_db__x3A__BI_audit_ENERGA_RUM_KONTRAHENCI_POWIAZANIA:BI_audit_ENERGA_RUM_KONTRAHENCI_POWIAZANIA',
- 'examples' => [
- 'BiAudit' => "",
- 'BiAudit lvl3' => "<wfs:Query>" . implode("\n\t", [
- "<wfs:PropertyName>A_ADM_COMPANY</wfs:PropertyName>",
- "<wfs:PropertyName>A_CLASSIFIED</wfs:PropertyName>",
- "<wfs:PropertyName>A_STATUS</wfs:PropertyName>",
- "<wfs:PropertyName>A_STATUS_INFO</wfs:PropertyName>",
- "<wfs:PropertyName>BI_analiza_depth</wfs:PropertyName>",
- "<wfs:PropertyName>BI_analiza_reloadCache</wfs:PropertyName>",
- "<wfs:PropertyName>FILE_STATUS</wfs:PropertyName>",
- "<wfs:PropertyName>FILE_STATUS_info</wfs:PropertyName>",
- "<wfs:PropertyName>ID</wfs:PropertyName>",
- "<wfs:PropertyName>L_APPOITMENT_USER</wfs:PropertyName>",
- "<wfs:PropertyName>default_db__x3A__BI_audit_ENERGA_PRACOWNICY:BI_audit_ENERGA_PRACOWNICY/*</wfs:PropertyName>",
- "<wfs:PropertyName>default_db__x3A__BI_audit_ENERGA_RUM_KONTRAHENCI:BI_audit_ENERGA_RUM_KONTRAHENCI/*</wfs:PropertyName>",
- "<wfs:PropertyName>default_db__x3A__BI_audit_ENERGA_RUM_KONTRAHENCI_POWIAZANIA_row:BI_audit_ENERGA_RUM_KONTRAHENCI_POWIAZANIA_row/*</wfs:PropertyName>",
- "<wfs:PropertyName>default_db__x3A__BI_audit_KW_requested_person:BI_audit_KW_requested_person/*</wfs:PropertyName>",
- ]) . "\n" . "</wfs:Query>",
- ],
- ];
- echo UI::h('script', [], "
- var examples = " . json_encode($examples) . ";
- console.log('examples', examples)
- function setWfsExample(label, i) {
- console.log('label', label, 'i', i)
- document.getElementById('wfsRequestFeatureTypeName').value = examples[label].typeName
- document.getElementById('wfsRequestBody').value = examples[label].examples[i]
- sendWfsRequest()
- }
- for (var label in examples) {
- for (var i in examples[label].examples) {
- jQuery(document.getElementById('wfs-example-btns')).append('<button class=\"btn btn-default\" style=\"margin-left:12px\" onClick=\"setWfsExample(\''+label+'\', \''+i+'\')\">'+i+'</button>')
- }
- }
- ");
- echo UI::h('script', [], "
- function sendWfsRequest() {
- document.getElementById('wfsResponse').innerHTML = 'loading...'
- var featureTypeName = document.getElementById('wfsRequestFeatureTypeName').value
- var postBody = document.getElementById('wfsRequestBody').value.replace(/</g, '<').replace(/>/g, '>')
- console.log('wfsRequestBody:', postBody)
- p5WFS_GetFeature(featureTypeName, Object.assign({
- 'maxFeatures': 5,
- }, (!postBody) ? {} : { 'ogc:Filter': postBody }
- )).then(function (features) {
- console.log('features', features)
- document.getElementById('wfsResponse').innerHTML = JSON.stringify(features, null, 2)
- }).catch(function (e) {
- console.warn(e)
- document.getElementById('wfsResponse').innerHTML = JSON.stringify(e, null, 2)
- p5UI__notifyAjaxCallback({ type: 'error', msg: e })
- })
- return false
- }
- (function () {
- console.log('p5WFS_GetFeature() ...')
- sendWfsRequest()
- })()
- ");
- } catch (Exception $e) {
- UI::alert('danger', $e);
- }
- UI::dol();
- }
- }
|