From 9bdb963065f52323f50536570fb505ac25465cde Mon Sep 17 00:00:00 2001 From: StC-OSM <100076956+StC-OSM@users.noreply.github.com> Date: Sat, 29 Jun 2024 10:20:41 +0200 Subject: [PATCH] =?UTF-8?q?Created=20analyser=20for=20France=E2=80=99s=20O?= =?UTF-8?q?NF=20data=20on=20public=20forests?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../analyser_merge_forest_compartment_FR.py | 60 +++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 analysers/analyser_merge_forest_compartment_FR.py diff --git a/analysers/analyser_merge_forest_compartment_FR.py b/analysers/analyser_merge_forest_compartment_FR.py new file mode 100644 index 000000000..62f38cb42 --- /dev/null +++ b/analysers/analyser_merge_forest_compartment_FR.py @@ -0,0 +1,60 @@ +#!/usr/bin/env python +#-*- coding: utf-8 -*- + +########################################################################### +## ## +## Copyright StC 2024 ## +## ## +## This program is free software: you can redistribute it and/or modify ## +## it under the terms of the GNU General Public License as published by ## +## the Free Software Foundation, either version 3 of the License, or ## +## (at your option) any later version. ## +## ## +## This program is distributed in the hope that it will be useful, ## +## but WITHOUT ANY WARRANTY; without even the implied warranty of ## +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ## +## GNU General Public License for more details. ## +## ## +## You should have received a copy of the GNU General Public License ## +## along with this program. If not, see . ## +## ## +########################################################################### + +from modules.OsmoseTranslation import T_ +from .Analyser_Merge import Analyser_Merge_Point, Source, SHP, Load_XY, Conflate, Select, Mapping + + +class Analyser_Merge_Forest_Compartment_FR(Analyser_Merge_Point): + requires_tables_common = ['polygons'] + + def __init__(self, config, logger = None): + Analyser_Merge_Point.__init__(self, config, logger) + self.def_class_missing_official(item = 8550, id = 1, level = 3, tags = ['merge', 'boundary', 'fix:survey', 'fix:imagery'], + title = T_('Forest compartment not integrated'), + fix = T_('Please use the geopf.fr WMTS FORETS.PUBLIQUES service or the ONF data at http://metadata.carmencarto.fr/geonetwork/105/api/records/fr-662043116-82880F0D-E1C4-4EF3-80AF-416977F118F1 to create the appropriate boundary with forest compartment tags in OSM'), + trap = T_('Do not import to OSM the POI created by Osmose, which is just there to help you locate the missing forest compartment')) + + self.init( + 'http://metadata.carmencarto.fr/geonetwork/105/api/records/fr-662043116-82880F0D-E1C4-4EF3-80AF-416977F118F1', + 'parcelles forestières', + SHP(Source( + attribution='Office National des Forêts', + millesime='2023-03-12', + fileUrl='http://ws.carmencarto.fr/WFS/105/ONF_Forets?request=GetFeature&service=WFS&version=1.1.0&typeName=PARC_PUBL_FR&outputFormat=SHAPE'), + zip='PARC_PUBL_FR.shp'), + Load_XY(('ST_X(ST_PointOnSurface(geom))',), ('ST_Y(ST_PointOnSurface(geom))',)), + Conflate( + select = Select( + types = ['nodes', 'polygons'], + tags = {'boundary': 'forest_compartment'}), + conflationDistance = 0, + mapping = Mapping( + static1 = {'type': 'boundary'}, + static2 = {'boundary': 'forest_compartment'}, + mapping1 = { + 'ref' : 'ccod_prf', + 'name' : 'llib_frt' + }, + ) + ) + )