[fusion-commits] r2953 - in branches/fusion-mg26: . layers/MapGuide/php widgets/BufferPanel widgets/Query/classes widgets/Redline/classes widgets/Search widgets/SelectWithin
svn_fusion at osgeo.org
svn_fusion at osgeo.org
Wed Jul 27 05:54:40 PDT 2016
Author: jng
Date: 2016-07-27 05:54:40 -0700 (Wed, 27 Jul 2016)
New Revision: 2953
Modified:
branches/fusion-mg26/
branches/fusion-mg26/layers/MapGuide/php/Buffer.php
branches/fusion-mg26/layers/MapGuide/php/Common.php
branches/fusion-mg26/layers/MapGuide/php/Query.php
branches/fusion-mg26/widgets/BufferPanel/Buffer.php
branches/fusion-mg26/widgets/Query/classes/query.php
branches/fusion-mg26/widgets/Redline/classes/markupeditor.php
branches/fusion-mg26/widgets/Redline/classes/markupmanager.php
branches/fusion-mg26/widgets/Search/Search.php
branches/fusion-mg26/widgets/SelectWithin/SelectWithin.php
Log:
Merged revision(s) 2950 from trunk:
#651: Use MgFeatureQueryOptions with explicit property lists where applicable.
This is to ensure that a "select * from featureclass" query from relational FDO providers will have its column list bounded to what is recognized in the class definition returned by the provider. Some providers are known to produce "select * from table" queries that "leak" out column types that the provider does not know how to process. Using an explicit property list from its class definition will allow us to avoid such issues.
The redline widget is exempt from this as its underlying data stores will be either SDF, SHP or SQLite. None of the aforementioned FDO providers have this problem.
........
Property changes on: branches/fusion-mg26
___________________________________________________________________
Modified: svn:mergeinfo
- /branches/fusion-mg24:2560
/sandbox/adsk/2.6l:2911
/sandbox/adsk/3.1n:2925-2927
/sandbox/createruntimemap:2699-2708
/sandbox/jxlib-3.0:1957-2248
/sandbox/ol213:2801-2803
/sandbox/robust_error_handling:2818-2825
/trunk:2847,2850,2857,2859,2862-2863,2872,2877,2880,2882,2884,2893-2897,2899,2905-2908,2915,2920-2932,2936-2942,2946
+ /branches/fusion-mg24:2560
/sandbox/adsk/2.6l:2911
/sandbox/adsk/3.1n:2925-2927
/sandbox/createruntimemap:2699-2708
/sandbox/jxlib-3.0:1957-2248
/sandbox/ol213:2801-2803
/sandbox/robust_error_handling:2818-2825
/trunk:2847,2850,2857,2859,2862-2863,2872,2877,2880,2882,2884,2893-2897,2899,2905-2908,2915,2920-2932,2936-2942,2946,2950
Modified: branches/fusion-mg26/layers/MapGuide/php/Buffer.php
===================================================================
--- branches/fusion-mg26/layers/MapGuide/php/Buffer.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/layers/MapGuide/php/Buffer.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -123,7 +123,6 @@
}
//loop through the selection of the input layer. If no selection, select all features
- $queryOptions = new MgFeatureQueryOptions();
$selection = new MgSelection($map);
$selection->Open($resourceService, $mapName);
$selLayers = $selection->GetLayers();
@@ -143,6 +142,8 @@
if ($filter == '') {
continue;
}
+ $clsDef = $selLayer->GetClassDefinition();
+ $queryOptions = BuildFeatureQueryOptions($clsDef);
$queryOptions->SetFilter($filter);
$featureSource = new MgResourceIdentifier($selLayer->GetFeatureSourceId());
$featureReader = $featureService->SelectFeatures($featureSource, $featureClassName, $queryOptions);
Modified: branches/fusion-mg26/layers/MapGuide/php/Common.php
===================================================================
--- branches/fusion-mg26/layers/MapGuide/php/Common.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/layers/MapGuide/php/Common.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -309,4 +309,63 @@
return "Fusion Viewer";
}
+// Builds a MgFeatureQueryOptions with an explicit property list based
+// on the given class definition
+//
+// This is to ensure that a "select * from featureclass" query from relational
+// providers will have its column list bounded to what is recognized in the
+// class definition. Some providers are known to produce "select * from table"
+// queries that "leak" out column types that the provider does not know how to
+// process. Using an explicit property list from its class definition will
+// allow us to avoid such issues
+function BuildFeatureQueryOptions($classDef)
+{
+ $query = new MgFeatureQueryOptions();
+ $geomPropName = $classDef->GetDefaultGeometryPropertyName();
+ $propertyList = $classDef->GetProperties();
+
+ for ($i = 0; $i < $propertyList->GetCount(); $i++)
+ {
+ $propertyDef = $propertyList->GetItem($i);
+ $property = $propertyList->GetItem($i)->GetName();
+
+ if (($property != $geomPropName) && ($propertyDef->GetPropertyType() == MgFeaturePropertyType::DataProperty))
+ {
+ $propertyType = $propertyList->GetItem($i)->GetDataType();
+ switch ($propertyType) {
+ case MgPropertyType::Boolean:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Byte:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::DateTime:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Single:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Double:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Int16:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Int32:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::Int64:
+ $query->AddFeatureProperty($property);
+ break;
+ case MgPropertyType::String:
+ $query->AddFeatureProperty($property);
+ break;
+ }
+ } else if ($property == $geomPropName){
+ $query->AddFeatureProperty($property);
+ }
+ }
+ return $query;
+}
+
?>
Modified: branches/fusion-mg26/layers/MapGuide/php/Query.php
===================================================================
--- branches/fusion-mg26/layers/MapGuide/php/Query.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/layers/MapGuide/php/Query.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -288,16 +288,18 @@
if ($bExtendSelection) {
$selection = new MgSelection($map);
- $queryOptions = new MgFeatureQueryOptions();
$layers = $map->GetLayers();
foreach($aLayers as $szLayer => $aLayer) {
$oLayer = $layers->GetItem($szLayer);
foreach($aLayer as $szClass => $aFilter) {
+ $clsDef = $oLayer->GetClassDefinition();
+ $queryOptions = BuildFeatureQueryOptions($clsDef);
+
/* get the feature source from the layer */
$featureResId = new MgResourceIdentifier($oLayer->GetFeatureSourceId());
$featureGeometryName = $oLayer->GetFeatureGeometryName();
$szFilter = implode(' OR ', $aFilter);
- $queryOptions->setFilter($szFilter);
+ $queryOptions->SetFilter($szFilter);
/* the class that is used for this layer will be used to select
features */
$class = $oLayer->GetFeatureClassName();
Modified: branches/fusion-mg26/widgets/BufferPanel/Buffer.php
===================================================================
--- branches/fusion-mg26/widgets/BufferPanel/Buffer.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/BufferPanel/Buffer.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -253,7 +253,8 @@
if($filter == "")
continue;
- $query = new MgFeatureQueryOptions();
+ $clsDef = $selLayer->GetClassDefinition();
+ $query = BuildFeatureQueryOptions($clsDef);
$query->SetFilter($filter);
$featureSource = new MgResourceIdentifier($selLayer->GetFeatureSourceId());
Modified: branches/fusion-mg26/widgets/Query/classes/query.php
===================================================================
--- branches/fusion-mg26/widgets/Query/classes/query.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/Query/classes/query.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -253,7 +253,8 @@
// Execute the query
$queryMax = (int) $this->args['QUERYMAX'];
- $queryOptions = new MgFeatureQueryOptions();
+ $clsDef = $layer->GetClassDefinition();
+ $queryOptions = BuildFeatureQueryOptions($clsDef);
$propertyFilter = '';
if ($this->args['USEPROPERTYFILTER'] == 'true')
Modified: branches/fusion-mg26/widgets/Redline/classes/markupeditor.php
===================================================================
--- branches/fusion-mg26/widgets/Redline/classes/markupeditor.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/Redline/classes/markupeditor.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -56,7 +56,13 @@
$featureService = $this->site->CreateService(MgServiceType::FeatureService);
$featureSourceId = $this->GetFeatureSource();
+ //NOTE: Normally we'd always pass in a MgFeatureQueryOptions with an explicit property
+ //list, but we're dealing with a series of FDO providers (SDF,SHP,SQLite) that are known
+ //to *not* have the issue of potentially leaking out column types in the query result that
+ //the underlying FDO provider doesn't know how to translate to FDO logical properties, so
+ //passing null is acceptable here
$featureReader = $featureService->SelectFeatures($featureSourceId, 'Markup', null);
+
//HACK: Another leaky abstraction. SHP will always choose FeatId, so once again
//use the class definition to determine the identity property name
$clsDef = $featureReader->GetClassDefinition();
Modified: branches/fusion-mg26/widgets/Redline/classes/markupmanager.php
===================================================================
--- branches/fusion-mg26/widgets/Redline/classes/markupmanager.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/Redline/classes/markupmanager.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -103,6 +103,11 @@
$featureService = $this->site->CreateService(MgServiceType::FeatureService);
$query = new MgFeatureQueryOptions();
$query->SetFilter("LayerDefinition = '$layerDefinitionId'");
+ //NOTE: Normally we'd always pass in a MgFeatureQueryOptions with an explicit property
+ //list, but we're dealing an FDO provider (SDF) that is known to *not* have the issue of
+ //potentially leaking out column types in the query result that the underlying FDO provider
+ //doesn't know how to translate to FDO logical properties, so passing the MgFeatureQueryOptions
+ //as-is is fine here.
$fr = $featureService->SelectFeatures($this->markupRegistryId, "Default:MarkupRegistry", $query);
$fsId = "";
@@ -118,6 +123,11 @@
$featureService = $this->site->CreateService(MgServiceType::FeatureService);
$query = new MgFeatureQueryOptions();
$query->SetFilter("LayerDefinition = '$markupLayerResId'");
+ //NOTE: Normally we'd always pass in a MgFeatureQueryOptions with an explicit property
+ //list, but we're dealing an FDO provider (SDF) that is known to *not* have the issue of
+ //potentially leaking out column types in the query result that the underlying FDO provider
+ //doesn't know how to translate to FDO logical properties, so passing the MgFeatureQueryOptions
+ //as-is is fine here.
$fr = $featureService->SelectFeatures($this->markupRegistryId, "Default:MarkupRegistry", $query);
$fdoProvider = "";
@@ -144,6 +154,11 @@
//Query the markup registry
$featureService = $this->site->CreateService(MgServiceType::FeatureService);
$query = new MgFeatureQueryOptions();
+ //NOTE: Normally we'd always pass in a MgFeatureQueryOptions with an explicit property
+ //list, but we're dealing an FDO provider (SDF) that is known to *not* have the issue of
+ //potentially leaking out column types in the query result that the underlying FDO provider
+ //doesn't know how to translate to FDO logical properties, so passing the MgFeatureQueryOptions
+ //as-is is fine here.
$fr = $featureService->SelectFeatures($this->markupRegistryId, "Default:MarkupRegistry", $query);
while($fr->ReadNext())
{
Modified: branches/fusion-mg26/widgets/Search/Search.php
===================================================================
--- branches/fusion-mg26/widgets/Search/Search.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/Search/Search.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -115,7 +115,8 @@
$displayAll = (count($resProps) == 0);
//query the features
- $opts = new MgFeatureQueryOptions();
+ $clsDef = $layer->GetClassDefinition();
+ $opts = BuildFeatureQueryOptions($clsDef);
$opts->SetFilter($filter);
$featureClassName = $layer->GetFeatureClassName();
$srcId = new MgResourceIdentifier($layer->GetFeatureSourceId());
Modified: branches/fusion-mg26/widgets/SelectWithin/SelectWithin.php
===================================================================
--- branches/fusion-mg26/widgets/SelectWithin/SelectWithin.php 2016-07-27 12:54:22 UTC (rev 2952)
+++ branches/fusion-mg26/widgets/SelectWithin/SelectWithin.php 2016-07-27 12:54:40 UTC (rev 2953)
@@ -108,8 +108,9 @@
for ($i=0; $i<$layers->GetCount(); $i++) {
$layer = $layers->GetItem($i);
$layerName = $layer->GetName();
+ $clsDef = $layer->GetClassDefinition();
$layerClassName = $layer->GetFeatureClassName();
- $options = new MgFeatureQueryOptions();
+ $options = BuildFeatureQueryOptions($clsDef);
$options->SetFilter($resultSel->GenerateFilter($layer, $layerClassName));
$resourceId = new MgResourceIdentifier($layer->GetFeatureSourceId());
$featureReader = $featureSrvc->SelectFeatures($resourceId, $layerClassName, $options);
@@ -159,7 +160,8 @@
{
$layer = $selLayers->GetItem($i);
$filter = $sel->GenerateFilter($layer, $layer->GetFeatureClassName());
- $query = new MgFeatureQueryOptions();
+ $clsDef = $layer->GetClassDefinition();
+ $query = BuildFeatureQueryOptions($clsDef);
$query->SetFilter($filter);
$featureSource = new MgResourceIdentifier($layer->GetFeatureSourceId());
$features = $featureSrvc->SelectFeatures($featureSource, $layer->GetFeatureClassName(), $query);
More information about the fusion-commits
mailing list