diff --git a/web_service/conf/properties.inc b/web_service/conf/properties.inc index 1860f88996469d2b1e1696ae222a8ec8e1e2655a..30cca53b57a4cd36fe60d5592054d93710d6807f 100755 --- a/web_service/conf/properties.inc +++ b/web_service/conf/properties.inc @@ -56,6 +56,9 @@ $properties["cadastre"]["views"]["voie"] = "v_vmap_maj_fv"; // Tolérence d'intersection (en %) $properties["cadastre"]["descr_parcel"]["intersect"]["tolerance"] = 1; +// Si une colonne id_com est définie dans la table intersectée, alors elle sera utilisée en plus de l'intersection spatiale +$properties["cadastre"]["descr_parcel"]["intersect"]["intersect_id_com"] = true; + // On peut donner soit un logo soit un nom de company $properties["cadastre"]["fiche_urb"]["logo"] = ""; @@ -94,4 +97,8 @@ $properties["cadastre"]["view"]["bati"] = "s_cadastre.v_vmap_batiment"; // Tolérence d'intersection (en %) $properties["cadastre"]["fiche_urb"]["intersect"]["tolerance"] = 1; + +// Si une colonne id_com est définie dans la table intersectée, alors elle sera utilisée en plus de l'intersection spatiale +$properties["cadastre"]["fiche_urb"]["intersect"]["intersect_id_com"] = true; + ?> diff --git a/web_service/sql/sqlQueries.xml b/web_service/sql/sqlQueries.xml index a61dcbb2b8e395f05a70745ba1ea29624a20deaa..2249532b0e58eca5f3e319a440fcb3da2a5c91a7 100644 --- a/web_service/sql/sqlQueries.xml +++ b/web_service/sql/sqlQueries.xml @@ -1515,7 +1515,7 @@ ALTER TABLE ONLY "s_cadastre"."tc_sym" ADD CONSTRAINT "tc_sym_pkey" PRIMARY KEY ("sym_code"); ALTER TABLE ONLY "s_cadastre"."tc_can" ADD CONSTRAINT "tc_can_pkey" PRIMARY KEY ("can_code"); ALTER TABLE ONLY "s_cadastre"."tc_copl" ADD CONSTRAINT "tc_copl_pkey" PRIMARY KEY ("copl_code"); - CREATE TABLE "s_cadastre".version ( version character varying(10) NOT NULL, build integer NOT NULL, date timestamp with time zone NOT NULL, active boolean ) WITH (OIDS = FALSE); + CREATE TABLE "s_cadastre".version ( version character varying(100) NOT NULL, build integer NOT NULL, date timestamp with time zone NOT NULL, active boolean ) WITH (OIDS = FALSE); ALTER TABLE "s_cadastre".version OWNER TO u_vitis; CREATE TABLE "s_cadastre".batiment (id bigserial NOT NULL,id_com character(5) NOT NULL,dur_code character (2),pre character(3),section character(2), geom public.geometry(MultiPolygon), CONSTRAINT enforce_srid_geom CHECK (st_srid(geom) = $(SRID))) WITH (OIDS=FALSE); ALTER TABLE "s_cadastre".batiment OWNER TO u_vitis; diff --git a/web_service/ws/FicheDescriptiveParcelle.class.inc b/web_service/ws/FicheDescriptiveParcelle.class.inc index 8a6980d116115cbf035d7f9aba300f10cdc08d02..112f1f9a77934a075bb4d683c24946595ec3a882 100755 --- a/web_service/ws/FicheDescriptiveParcelle.class.inc +++ b/web_service/ws/FicheDescriptiveParcelle.class.inc @@ -14,7 +14,7 @@ require_once dirname($_SERVER['SCRIPT_FILENAME']) . '/class/vmlib/BdDataAccess.i * \brief This file contains the FicheDescriptiveParcelle php class * * This class defines the rest api for fichedescriptiveparcelle - * + * */ class FicheDescriptiveParcelle extends Cadastre { /** @@ -144,6 +144,7 @@ class FicheDescriptiveParcelle extends Cadastre { // Infos complémentaires (paramétrées par l'administrateur) $iTolerance = $this->aProperties["cadastre"]["descr_parcel"]["intersect"]["tolerance"]; + $bInterectIdCom = $this->aProperties["cadastre"]["descr_parcel"]["intersect"]["intersect_id_com"]; $aIntersectionViews = $this->aProperties['cadastre']['descr_parcel']['intersect']['views']; // Récupère la géométrie de la parcelle @@ -192,6 +193,17 @@ class FicheDescriptiveParcelle extends Cadastre { $aIntersect = $this->vmapIntersectGet($sSchema, $sTable, $parcelleGeom, $aAttributs, $iTolerance, $sGeomColumn, $sGeomType); + // Supprime les intersections qui ne sont pas de le même commune + if ($bInterectIdCom == true) { + foreach ($aIntersect as $key2 => $value2) { + if (!empty($value2['id_com'])) { + if ($value2['id_com'] != substr($ID_PAR,0,5)) { + unset($aIntersect[$key2]); + } + } + } + } + $value['data'] = $aIntersect; if (isset($value['data'][0]) && !empty($value['data'][0])) { $value['aFields'] = array_keys($value['data'][0]); @@ -207,4 +219,4 @@ class FicheDescriptiveParcelle extends Cadastre { } -?> \ No newline at end of file +?> diff --git a/web_service/ws/FicheUrbanisme.class.inc b/web_service/ws/FicheUrbanisme.class.inc index 841ac4397f85ebb9a366559684b55629e97fbbc1..349698f30d94b32f4f73c3008270217262937af9 100755 --- a/web_service/ws/FicheUrbanisme.class.inc +++ b/web_service/ws/FicheUrbanisme.class.inc @@ -132,6 +132,7 @@ class FicheUrbanisme extends Cadastre { // Infos complémentaires (paramétrées par l'administrateur) $aIntersectionViews = $this->aProperties['cadastre']['fiche_urb']['intersect']['views']; $iTolerance = $this->aProperties["cadastre"]["fiche_urb"]["intersect"]["tolerance"]; + $bInterectIdCom = $this->aProperties["cadastre"]["fiche_urb"]["intersect"]["intersect_id_com"]; if (is_array($aIntersectionViews)) { foreach ($aIntersectionViews as $key => $value) { if (strpos($key, ".") === false) { @@ -165,6 +166,17 @@ class FicheUrbanisme extends Cadastre { $aIntersect = $this->vmapIntersectGet($sSchema, $sTable, $parcelleGeom, $aAttributs, $iTolerance, $sGeomColumn, $sGeomType); + // Supprime les intersections qui ne sont pas de le même commune + if ($bInterectIdCom == true) { + foreach ($aIntersect as $key2 => $value2) { + if (!empty($value2['id_com'])) { + if ($value2['id_com'] != substr($ID_PAR,0,5)) { + unset($aIntersect[$key2]); + } + } + } + } + $value['data'] = $aIntersect; $value['attributs'] = $aOrderedKeys;