title = $title; } public $title; } $locale = ""; $userInput = ""; $target = 0; $popup = 0; $layerName = ""; $mapName = ""; $sessionId = ""; $filter = ""; $resNames = array(); $resProps = array(); $matchLimit = 0; $features = NULL; GetRequestParameters(); SetLocalizedFilesPath(GetLocalizationPath()); $searchError = GetLocalizedString("SEARCHERROR", $locale); try { InitializeWebTier(); $cred = new MgUserInformation($sessionId); $cred->SetClientIp(GetClientIp()); $cred->SetClientAgent(GetClientAgent()); //connect to the site and get a feature service and a resource service instances $site = new MgSiteConnection(); $site->Open($cred); $featureSrvc = $site->CreateService(MgServiceType::FeatureService); //Create a temporary map runtime object, locate the layer $map = new MgMap($site); $map->Open($mapName); $layers = $map->GetLayers(); $layer = null; for($i = 0; $i < $layers->GetCount(); $i++) { $layer = $layers->GetItem($i); if($layer->GetName() == $layerName) break; } if($layer == null) { trigger_error(FormatMessage("SEARCHLAYERNOTFOUND", $locale, array($layerName))); } $userInput = str_replace("'", "''", $userInput); //unescape strings // if(ini_get("magic_quotes_sybase") == "1") { $matchLabel = str_replace("''", "'", $matchLabel); $filter = str_replace("''", "'", $filter); } else if(get_magic_quotes_gpc() == "1") { //Unescape single quotes $filter = str_replace("\\'", "'", $filter); //Unescape double quotes $filter = str_replace('\\"', '"', $filter); //remove additional backslash $filter = str_replace("\\", "", $filter); } //substitute the input tag with the actual user input to make up the filter $filter = str_replace('$USER_VARIABLE', $userInput, $filter); //parse the match label string, which defines what columns to be displayed $displayAll = (count($resProps) == 0); //query the features $clsDef = $layer->GetClassDefinition(); $opts = BuildFeatureQueryOptions($clsDef); $opts->SetFilter($filter); $featureClassName = $layer->GetFeatureClassName(); $features = $layer->SelectFeatures($opts); $hasResult = $features->ReadNext(); if($hasResult) { $colCount = $displayAll? $features->GetPropertyCount(): count($resProps); //output the beginning of the document (head section and beginning of body section) $templ = file_get_contents("../viewerfiles/search.templ"); $templ = Localize($templ, $locale, GetClientOS()); print sprintf($templ, $colCount, $target, $popup); $classDef = $features->GetClassDefinition(); $idProps = $classDef->GetIdentityProperties(); $idPropNames = array(); for($j = 0; $j < $idProps->GetCount(); $j++) { $idProp = $idProps->GetItem($j); array_push($idPropNames, $idProp->GetName()); } //table headings echo ""; if($displayAll) { for($i = 0; $i < $colCount; $i++) { $resProps[$i] = $features->GetPropertyName($i); echo " " . $resProps[$i] . ""; } } else { for($i = 0; $i < $colCount; $i++) echo " " . $resNames[$i] . ""; } echo ""; //output the results $row = 0; do { echo ""; for($i = 0; $i < $colCount; $i++) { $propName = $resProps[$i]; $propType = $features->GetPropertyType($resProps[$i]); $val = ""; if (!$features->IsNull($propName)) { switch($propType) { case MgPropertyType::Boolean: $val = $features->GetBoolean($propName)? "true": "false"; break; case MgPropertyType::Single: $val = $features->GetSingle($propName); break; case MgPropertyType::Double: $val = $features->GetDouble($propName); break; case MgPropertyType::Int16: $val = $features->GetInt16($propName); break; case MgPropertyType::Int32: $val = $features->GetInt32($propName); break; case MgPropertyType::Int64: $val = $features->GetInt64($propName); break; case MgPropertyType::String: $val = $features->GetString($propName); break; case MgPropertyType::DateTime: $val = $features->GetDateTime($propName)->ToString(); break; } } // Generate XML to selection this feature // $sel = new MgSelection($map); $idProps = new MgPropertyCollection(); foreach ($idPropNames as $id) { $idPropType = $features->GetPropertyType($id); switch($idPropType) { case MgPropertyType::Int32: $idProps->Add(new MgInt32Property($id, $features->GetInt32($id))); break; case MgPropertyType::String: $idProps->Add(new MgStringProperty($id, $features->GetString($id))); break; case MgPropertyType::Int64: $idProps->Add(new MgInt64Property($id, $features->GetInt64($id))); break; case MgPropertyType::Double: $idProps->Add(new MgDoubleProperty($id, $features->GetDouble($id))); break; case MgPropertyType::Single: $idProps->Add(new MgSingleProperty($id, $features->GetSingle($id))); break; case MgPropertyType::DateTime: $idProps->Add(new MgDateTimeProperty($id, $features->GetDateTime($id))); break; default: throw new SearchError(FormatMessage("SEARCHTYYPENOTSUP", $locale, array($idPropType)), $searchError); } } $sel->AddFeatureIds($layer, $featureClassName, $idProps); $selText = EscapeForHtml($sel->ToXml(), true); echo sprintf(" %s\n", !($row%2)? "Search" : "Search2", $row, $i, $row, $selText, $val); } echo ""; if (++ $row == $matchLimit) break; } while($features->ReadNext()); } else { throw new SearchError(GetLocalizedString("SEARCHNOMATCHES", $locale), GetLocalizedString("SEARCHREPORT", $locale)); } } catch(MgException $ae) { if($features) { // Close the feature reader $features->Close(); } OnError($searchError, $ae->GetDetails()); } catch(SearchError $e) { if($features) { // Close the feature reader $features->Close(); } OnError($e->title, $e->getMessage()); } //terminate the html document echo ""; // Set content length header header("Content-Length:".ob_get_length()); // Flush output buffer ob_end_flush(); function OnError($title, $msg) { global $target, $popup; $templ = file_get_contents("../viewerfiles/errorpage.templ"); print sprintf($templ, $popup, $title, $msg); } function GetParameters($params) { global $userInput, $target, $layerName, $popup, $locale; global $mapName, $sessionId, $filter, $resNames, $resProps, $matchLimit; $sessionId = ValidateSessionId(GetParameter($params, 'SESSION')); $locale = ValidateLocaleString(GetParameter($params, 'LOCALE')); $mapName = ValidateMapName(GetParameter($params, 'MAPNAME')); $target = GetIntParameter($params, 'TGT'); $popup = GetIntParameter($params, 'POPUP'); $matchLimit = GetIntParameter($params, 'MR'); $colCount = GetIntParameter($params, 'COLS'); if($colCount > 0) { for($i = 0; $i < $colCount; $i++) { array_push($resNames, GetParameter($params, 'CN' . $i)); array_push($resProps, GetParameter($params, 'CP' . $i)); } } $userInput = GetParameter($params, 'USERINPUT'); $layerName = GetParameter($params, 'LAYER'); $filter = GetParameter($params, 'FILTER'); } function GetRequestParameters() { if($_SERVER['REQUEST_METHOD'] == "POST") GetParameters($_POST); else GetParameters($_GET); } ?>