Skip to content

Latest commit

 

History

History
152 lines (138 loc) · 6.11 KB

README.md

File metadata and controls

152 lines (138 loc) · 6.11 KB

mapstore-update-service-url

python script to update service urls in a mapstore instance, when your service is renamed or moved to a new server, or a layer is migrated to another service, such as the french geoplateforme migration, cf https://geoservices.ign.fr/bascule-vers-la-geoplateforme

it can also remove no longer available services from all maps.

the following operations are available:

  • for a given catalog entry, replace its url (and eventually title)
"ignwmts" : {
  "action" : "replace",
  "by" : {
    "title" : "Géoplateforme WMTS",
    "url" : "https://data.geopf.fr/wmts"
  }
}
  • drop a given catalog entry by its name
"gpfbetarasterwms" : { "action" : "drop" }
  • rename a catalog entry (hidden to the user)
"sadre" : { "action" : "rename", "with": "sandre" }
  • for layers in a map from a given service url, replace the url
"https://wxs.ign.fr/essentiels/geoportail/wmts" : {
  "action" : "replace",
  "by" : {
    "url" : "https://data.geopf.fr/wmts"
  }
}
  • replace the url for a specific layer coming from a given service url, specifying its name
"https://wxs.ign.fr/parcellaire/geoportail/r/wms" : {
  "action" : "replace",
  "layername": "CADASTRALPARCELS.PARCELLAIRE_EXPRESS",
  "by" : {
    "url" : "https://data.geopf.fr/wms-r/wms"
  }
}
  • drop all layers coming from a given service url
"https://wxs.ign.fr/decouverte/geoportail/wmts" : { "action" : "drop" }
  • drop a specific layer coming from a given service url, specifying its name
"https://data.geopf.fr/wmts" : {
  "action" : "drop",
  "layername" : "ludi_2266__joincache_pyramide_2"
}

configuration

the script needs a list of service definitions mappings, from a previous url to a new url, or to nothing if the service/layer is to be removed. the configuration is stored in a json file, and an example is provided.

it will process (but only warn !) the following files:

  • /etc/georchestra/mapstore/configs/localConfig.json
  • /etc/georchestra/mapstore/configs/new.json
  • /etc/georchestra/mapstore/configs/config.json

and it will process (and update !) all entries in the mapstore schema found in the database pointed at by /etc/georchestra/default.properties

it will replace usage of layers pointing at the old url to the new url/servicename, and it will also update the list of catalogs available in the map.

usage

usage: process.py [-h] [-d] [-c CONFIG]

Process mapstore configs, maps & contexts.

optional arguments:
  -h, --help            show this help message and exit
  -d, --dry-run         dry-run mode
  -c CONFIG, --config CONFIG
                        json configuration file (defaults to config.json)

if using -d the script wont modify anything, but will tell you what it has found needing modifications.

example

in the below example, a previous run already cleaned up all the entries in the database, but there are still entries to remove in localConfig.json - the script won't change those but will warn as long as they're here !

[email protected]:~/scratch/mapstore-update-service-url $python3 process.py
catalog ignvectorwms should be updated in localConfig.json:
replace url by 'https://data.geopf.fr/wms-v/wms' and title by 'Géoplateforme VECTOR' in {'url': 'https://wxs.ign.fr/essentiels/geoportail/v/wms', 'type': 'wms', 'title': 'IGN essentiels VECTOR', 'autoload': True}
catalog igncartovectowms should be removed in localConfig.json, drop the following section:
{'url': 'https://wxs.ign.fr/cartovecto/geoportail/v/wms', 'type': 'wms', 'title': 'IGN carto vectorielle', 'autoload': True}
catalog ignadministratifwms should be removed in localConfig.json, drop the following section:
{'url': 'https://wxs.ign.fr/administratif/geoportail/r/wms', 'type': 'wms', 'title': 'IGN administratif', 'autoload': True}
catalog ignadressewms should be removed in localConfig.json, drop the following section:
{'url': 'https://wxs.ign.fr/adresse/geoportail/v/wms', 'type': 'wms', 'title': 'IGN adresse', 'autoload': True}
catalog ignagriculturewms should be removed in localConfig.json, drop the following section:
{'url': 'https://wxs.ign.fr/agriculture/geoportail/r/wms', 'type': 'wms', 'title': 'IGN agriculture', 'autoload': True}
catalog ignaltimetriewmts should be removed in localConfig.json, drop the following section:
{'url': 'https://wxs.ign.fr/altimetrie/geoportail/wmts', 'type': 'wmts', 'title': 'IGN altimetrie WMTS', 'autoload': True}
catalog ifremer should be removed in localConfig.json, drop the following section:
{'NOTE': 'NOT WORKING, requires login. This is configured on the current viewer but do not provide any response', 'url': 'http://www.ifremer.fr/geonetwork/srv/fre/csw', 'type': 'csw', 'title': "le catalogue de l'Ifremer", 'autoload': True}
connected to user=georchestra password=xxx dbname=georchestra host=localhost port=5432
nothing to fix in map 19 (test2)
nothing to fix in map 150 (test pane)
nothing to fix in map 66 (ortho)
nothing to fix in map 85 (Test Carte avec widgets)
nothing to fix in map 106 (xx)
nothing to fix in map 100 (test)
nothing to fix in map 34 (travaux)
nothing to fix in map 58 (mauzun orthohisto)
nothing to fix in context 156 (public_print)
nothing to fix in context 1 (test_theme)
nothing to fix in context 82 (test_widget)
nothing to fix in context 117 (aaaaaaa)
nothing to fix in context 93 (all_plugins)
nothing to fix in context 120 (blu)
nothing to update in the database !

and once everything is clean:

[email protected]:~/scratch/mapstore-update-service-url $python3 process.py
connected to user=georchestra password=xxx dbname=georchestra host=localhost port=5432
nothing to fix in map 19 (test2)
nothing to fix in map 150 (test pane)
nothing to fix in map 66 (ortho)
nothing to fix in map 85 (Test Carte avec widgets)
nothing to fix in map 106 (xx)
nothing to fix in map 100 (test)
nothing to fix in map 34 (travaux)
nothing to fix in map 58 (mauzun orthohisto)
nothing to fix in context 156 (public_print)
nothing to fix in context 1 (test_theme)
nothing to fix in context 82 (test_widget)
nothing to fix in context 117 (aaaaaaa)
nothing to fix in context 93 (all_plugins)
nothing to fix in context 120 (blu)
nothing to update in the database !