init repo
This commit is contained in:
commit
6524f02cb0
15 changed files with 1242 additions and 0 deletions
46
.env
Normal file
46
.env
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
# This file defines default environment variables for all images
|
||||||
|
|
||||||
|
# Layers definition and meta data
|
||||||
|
TILESET_FILE=vfosnarmaptiles.yaml
|
||||||
|
|
||||||
|
# Use 3-part patch version to ignore patch updates, e.g. 7.0.0
|
||||||
|
TOOLS_VERSION=7.1
|
||||||
|
|
||||||
|
# Make sure these values are in sync with the ones in .env-postgres file
|
||||||
|
PGDATABASE=vfosnarmaptiles
|
||||||
|
PGUSER=vfosnarmaptiles
|
||||||
|
PGPASSWORD=vfosnarmaptiles
|
||||||
|
PGHOST=postgres
|
||||||
|
PGPORT=5432
|
||||||
|
|
||||||
|
# BBOX may get overwritten by the computed bbox of the specific area:
|
||||||
|
# make generate-bbox-file
|
||||||
|
# By default, the Makefile will use the content of data/$(area).bbox file if it exists.
|
||||||
|
BBOX=-180.0,-85.0511,180.0,85.0511
|
||||||
|
|
||||||
|
# Which zooms to generate with make generate-tiles-pg
|
||||||
|
MIN_ZOOM=0
|
||||||
|
MAX_ZOOM=14
|
||||||
|
|
||||||
|
# `MID_ZOOM` setting only works with `make generate-tiles-pg` command. Make sure MID_ZOOM < MAX_ZOOM.
|
||||||
|
# See https://github.com/openmaptiles/openmaptiles-tools/pull/383
|
||||||
|
# MID_ZOOM=11
|
||||||
|
|
||||||
|
# Use true (case sensitive) to allow data updates
|
||||||
|
DIFF_MODE=false
|
||||||
|
|
||||||
|
# The current setup assumes this file is placed inside the data/ dir
|
||||||
|
MBTILES_FILE=tiles.mbtiles
|
||||||
|
|
||||||
|
# This is the current repl_config.json location, pre-configured in the tools Dockerfile
|
||||||
|
# Makefile and quickstart replace it with the dynamically generated one, but we keep it here in case some other method is used to run.
|
||||||
|
IMPOSM_CONFIG_FILE=/usr/src/app/config/repl_config.json
|
||||||
|
|
||||||
|
# Number of parallel processes to use when importing sql files
|
||||||
|
MAX_PARALLEL_PSQL=5
|
||||||
|
|
||||||
|
# Number of parallel threads to use when generating vector map tiles
|
||||||
|
COPY_CONCURRENCY=10
|
||||||
|
|
||||||
|
# Variables for generate tiles using tilelive-pgquery
|
||||||
|
PGHOSTS_LIST=
|
22
.gitignore
vendored
Normal file
22
.gitignore
vendored
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# Mapnik XML
|
||||||
|
data.xml
|
||||||
|
*.thumb.png
|
||||||
|
*.swp
|
||||||
|
*.pbf
|
||||||
|
|
||||||
|
# quickstart
|
||||||
|
quickstart.log
|
||||||
|
|
||||||
|
|
||||||
|
# imput / output data
|
||||||
|
data/*
|
||||||
|
|
||||||
|
# generated source files
|
||||||
|
build/*
|
||||||
|
|
||||||
|
# Import cache
|
||||||
|
cache/*
|
||||||
|
|
||||||
|
# any IDE files
|
||||||
|
.idea/
|
||||||
|
.vscode/
|
60
LICENSE.md
Normal file
60
LICENSE.md
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
Copyright (c) 2024, MapTiler.com & OpenMapTiles contributors.
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
The vector tile schema has been developed by Klokan Technologies GmbH and
|
||||||
|
was initially modelled after the cartography of the CARTO's Positron basemap
|
||||||
|
with permission from CartoDB Inc.
|
||||||
|
The vector tile schema has been refined and improved in cooperation with
|
||||||
|
the Wikimedia Foundation and is heavily influenced by years of
|
||||||
|
Paul Norman's experience of creating maps from OpenStreetMap data.
|
||||||
|
|
||||||
|
# Code license: BSD 3-Clause License
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
* Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
* Neither the name of the copyright holder nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived from
|
||||||
|
this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||||
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
# Design license: CC-BY 4.0
|
||||||
|
|
||||||
|
The cartography and visual design features of the map tile schema (also known as
|
||||||
|
the "look and feel" of the map) are licensed under the Creative Commons
|
||||||
|
Attribution 4.0 license.
|
||||||
|
To view a copy of the license, visit http://creativecommons.org/licenses/by/4.0/.
|
||||||
|
|
||||||
|
Products or services using maps derived from OpenMapTiles schema need to visibly
|
||||||
|
credit "OpenMapTiles.org" or reference "OpenMapTiles" with a link to
|
||||||
|
http://openmaptiles.org/.
|
||||||
|
|
||||||
|
For a browsable electronic map based on OpenMapTiles and OpenStreetMap data, the
|
||||||
|
credit should appear in the corner of the map. For example:
|
||||||
|
|
||||||
|
[© OpenMapTiles](http://openmaptiles.org/) [© OpenStreetMap contributors](http://www.openstreetmap.org/copyright)
|
||||||
|
|
||||||
|
For printed and static maps a similar attribution should be made in a textual
|
||||||
|
description near the image, in the same fashion as if you cite a photograph.
|
||||||
|
|
||||||
|
Exceptions to OpenMapTiles attribution requirement can be in a written form granted
|
||||||
|
by MapTiler (info@maptiler.com).
|
||||||
|
The project contributors grant MapTiler AG the license to give such
|
||||||
|
exceptions on a commercial basis.
|
697
Makefile
Normal file
697
Makefile
Normal file
|
@ -0,0 +1,697 @@
|
||||||
|
#
|
||||||
|
# First section - common variable initialization
|
||||||
|
#
|
||||||
|
|
||||||
|
# Ensure that errors don't hide inside pipes
|
||||||
|
SHELL = /usr/bin/env bash
|
||||||
|
.SHELLFLAGS = -o pipefail -c
|
||||||
|
|
||||||
|
# Layers definition and meta data
|
||||||
|
TILESET_FILE := $(or $(TILESET_FILE),$(shell (. .env; echo $${TILESET_FILE})),openmaptiles.yaml)
|
||||||
|
|
||||||
|
# Options to run with docker and docker-compose - ensure the container is destroyed on exit
|
||||||
|
# Containers run as the current user rather than root (so that created files are not root-owned)
|
||||||
|
DC_OPTS ?= --rm --user=$(shell id -u):$(shell id -g)
|
||||||
|
|
||||||
|
# If set to a non-empty value, will use postgis-preloaded instead of postgis docker image
|
||||||
|
USE_PRELOADED_IMAGE ?=
|
||||||
|
|
||||||
|
# Local port to use with postserve
|
||||||
|
PPORT ?= 8090
|
||||||
|
export PPORT
|
||||||
|
# Local port to use with tileserver
|
||||||
|
TPORT ?= 8080
|
||||||
|
export TPORT
|
||||||
|
STYLE_FILE := build/style/style.json
|
||||||
|
STYLE_HEADER_FILE := style/style-header.json
|
||||||
|
|
||||||
|
# Support newer `docker compose` syntax in addition to `docker-compose`
|
||||||
|
|
||||||
|
ifeq (, $(shell which docker-compose))
|
||||||
|
DOCKER_COMPOSE_COMMAND := docker compose
|
||||||
|
$(info Using docker compose V2 (docker compose))
|
||||||
|
else
|
||||||
|
DOCKER_COMPOSE_COMMAND := docker-compose
|
||||||
|
$(info Using docker compose V1 (docker-compose))
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Allow a custom docker-compose project name
|
||||||
|
DC_PROJECT := $(or $(DC_PROJECT),$(shell (. .env; echo $${DC_PROJECT})))
|
||||||
|
ifeq ($(DC_PROJECT),)
|
||||||
|
DC_PROJECT := $(notdir $(shell pwd))
|
||||||
|
DOCKER_COMPOSE := $(DOCKER_COMPOSE_COMMAND)
|
||||||
|
else
|
||||||
|
DOCKER_COMPOSE := $(DOCKER_COMPOSE_COMMAND) --project-name $(DC_PROJECT)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Make some operations quieter (e.g. inside the test script)
|
||||||
|
ifeq ($(or $(QUIET),$(shell (. .env; echo $${QUIET})))),)
|
||||||
|
QUIET_FLAG :=
|
||||||
|
else
|
||||||
|
QUIET_FLAG := --quiet
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Use `xargs --no-run-if-empty` flag, if supported
|
||||||
|
XARGS := xargs $(shell xargs --no-run-if-empty </dev/null 2>/dev/null && echo --no-run-if-empty)
|
||||||
|
|
||||||
|
# If running in the test mode, compare files rather than copy them
|
||||||
|
TEST_MODE?=no
|
||||||
|
ifeq ($(TEST_MODE),yes)
|
||||||
|
# create images in ./build/devdoc and compare them to ./layers
|
||||||
|
GRAPH_PARAMS=./build/devdoc ./layers
|
||||||
|
else
|
||||||
|
# update graphs in the ./layers dir
|
||||||
|
GRAPH_PARAMS=./layers
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Set OpenMapTiles host
|
||||||
|
export OMT_HOST := http://$(firstword $(subst :, ,$(subst tcp://,,$(DOCKER_HOST))) localhost)
|
||||||
|
|
||||||
|
# This defines an easy $(newline) value to act as a "\n". Make sure to keep exactly two empty lines after newline.
|
||||||
|
define newline
|
||||||
|
|
||||||
|
|
||||||
|
endef
|
||||||
|
|
||||||
|
# Use the old Postgres connection values as a fallback
|
||||||
|
PGHOST := $(or $(PGHOST),$(shell (. .env; echo $${PGHOST})),$(POSTGRES_HOST),$(shell (. .env; echo $${POSTGRES_HOST})),postgres)
|
||||||
|
PGPORT := $(or $(PGPORT),$(shell (. .env; echo $${PGPORT})),$(POSTGRES_PORT),$(shell (. .env; echo $${POSTGRES_PORT})),postgres)
|
||||||
|
PGDATABASE := $(or $(PGDATABASE),$(shell (. .env; echo $${PGDATABASE})),$(POSTGRES_DB),$(shell (. .env; echo $${POSTGRES_DB})),postgres)
|
||||||
|
PGUSER := $(or $(PGUSER),$(shell (. .env; echo $${PGUSER})),$(POSTGRES_USER),$(shell (. .env; echo $${POSTGRES_USER})),postgres)
|
||||||
|
PGPASSWORD := $(or $(PGPASSWORD),$(shell (. .env; echo $${PGPASSWORD})),$(POSTGRES_PASSWORD),$(shell (. .env; echo $${POSTGRES_PASSWORD})),postgres)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Determine area to work on
|
||||||
|
# If $(area) parameter is not set, and only one *.osm.pbf file is found in ./data, use it as $(area).
|
||||||
|
# Otherwise, all make targets requiring an area will show an error.
|
||||||
|
# Note: If no *.osm.pbf files are found, once the users call "make download area=..."
|
||||||
|
# they will not need to use an "area=" parameter again because there will be just a single file.
|
||||||
|
#
|
||||||
|
|
||||||
|
# historically we have been using $(area) rather than $(AREA), so make both work
|
||||||
|
area ?= $(AREA)
|
||||||
|
# Ensure the $(area) param is set, or try to automatically determine it based on available data files
|
||||||
|
ifeq ($(area),)
|
||||||
|
# An $(area) parameter is not set. If only one *.osm.pbf file is found in ./data, use it as $(area).
|
||||||
|
data_files := $(shell find data -name '*.osm.pbf' 2>/dev/null)
|
||||||
|
ifneq ($(word 2,$(data_files)),)
|
||||||
|
define assert_area_is_given
|
||||||
|
@echo ""
|
||||||
|
@echo "ERROR: The 'area' parameter or environment variable have not been set, and there several 'area' options:"
|
||||||
|
@$(patsubst data/%.osm.pbf,echo " '%'";,$(data_files))
|
||||||
|
@echo ""
|
||||||
|
@echo "To specify an area use:"
|
||||||
|
@echo " make $@ area=<area-id>"
|
||||||
|
@echo ""
|
||||||
|
@exit 1
|
||||||
|
endef
|
||||||
|
else
|
||||||
|
ifeq ($(word 1,$(data_files)),)
|
||||||
|
define assert_area_is_given
|
||||||
|
@echo ""
|
||||||
|
@echo "ERROR: The 'area' parameter (or env var) has not been set, and there are no data/*.osm.pbf files"
|
||||||
|
@echo ""
|
||||||
|
@echo "To specify an area use"
|
||||||
|
@echo " make $@ area=<area-id>"
|
||||||
|
@echo ""
|
||||||
|
@echo "To download an area, use make download area=<area-id>"
|
||||||
|
@echo "To list downloadable areas, use make list-geofabrik and/or make list-bbbike"
|
||||||
|
@exit 1
|
||||||
|
@echo ""
|
||||||
|
endef
|
||||||
|
else
|
||||||
|
# Keep just the name of the data file, without the .osm.pbf extension
|
||||||
|
area := $(patsubst data/%.osm.pbf,%,$(data_files))
|
||||||
|
# Rename area-latest.osm.pbf to area.osm.pbf
|
||||||
|
# TODO: This if statement could be removed in a few months once everyone is using the file without the `-latest`?
|
||||||
|
ifneq ($(area),$(area:-latest=))
|
||||||
|
$(shell mv "data/$(area).osm.pbf" "data/$(area:-latest=).osm.pbf")
|
||||||
|
area := $(area:-latest=)
|
||||||
|
$(warning ATTENTION: File data/$(area)-latest.osm.pbf was renamed to $(area).osm.pbf.)
|
||||||
|
AREA_INFO := Detected area=$(area) based on finding a 'data/$(area)-latest.osm.pbf' file - renamed to '$(area).osm.pbf'. Use 'area' parameter or environment variable to override.
|
||||||
|
else
|
||||||
|
AREA_INFO := Detected area=$(area) based on finding a 'data/$(area).osm.pbf' file. Use 'area' parameter or environment variable to override.
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(AREA_INFO),)
|
||||||
|
define assert_area_is_given
|
||||||
|
@echo "$(AREA_INFO)"
|
||||||
|
endef
|
||||||
|
endif
|
||||||
|
|
||||||
|
# If set, this file will be downloaded in download-osm and imported in the import-osm targets
|
||||||
|
PBF_FILE ?= data/$(area).osm.pbf
|
||||||
|
|
||||||
|
# For download-osm, allow URL parameter to download file from a given URL. Area param must still be provided.
|
||||||
|
DOWNLOAD_AREA := $(or $(url), $(area))
|
||||||
|
|
||||||
|
# The mbtiles file is placed into the $EXPORT_DIR=/export (mapped to ./data)
|
||||||
|
MBTILES_FILE := $(or $(MBTILES_FILE),$(shell (. .env; echo $${MBTILES_FILE})),$(area).mbtiles)
|
||||||
|
MBTILES_LOCAL_FILE = data/$(MBTILES_FILE)
|
||||||
|
|
||||||
|
DIFF_MODE := $(or $(DIFF_MODE),$(shell (. .env; echo $${DIFF_MODE})))
|
||||||
|
ifeq ($(DIFF_MODE),true)
|
||||||
|
# import-osm implementation requires IMPOSM_CONFIG_FILE to be set to a valid file
|
||||||
|
# For one-time only imports, the default value is fine.
|
||||||
|
# For diff mode updates, use the dynamically-generated area-based config file
|
||||||
|
export IMPOSM_CONFIG_FILE = data/$(area).repl.json
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Load area-specific bbox file that gets generated by the download-osm --bbox
|
||||||
|
AREA_BBOX_FILE ?= data/$(area).bbox
|
||||||
|
ifneq (,$(wildcard $(AREA_BBOX_FILE)))
|
||||||
|
cat := $(if $(filter $(OS),Windows_NT),type,cat)
|
||||||
|
BBOX := $(shell $(cat) ${AREA_BBOX_FILE})
|
||||||
|
export BBOX
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Consult .env if needed
|
||||||
|
MIN_ZOOM := $(or $(MIN_ZOOM),$(shell (. .env; echo $${MIN_ZOOM})),0)
|
||||||
|
MAX_ZOOM := $(or $(MAX_ZOOM),$(shell (. .env; echo $${MAX_ZOOM})),7)
|
||||||
|
PPORT := $(or $(PPORT),$(shell (. .env; echo $${PPORT})),7)
|
||||||
|
TPORT := $(or $(TPORT),$(shell (. .env; echo $${TPORT})),7)
|
||||||
|
|
||||||
|
define HELP_MESSAGE
|
||||||
|
==============================================================================
|
||||||
|
OpenMapTiles https://github.com/openmaptiles/openmaptiles
|
||||||
|
|
||||||
|
Hints for testing areas
|
||||||
|
make list-geofabrik # list actual geofabrik OSM extracts for download -> <<your-area>>
|
||||||
|
./quickstart.sh <<your-area>> # example: ./quickstart.sh madagascar
|
||||||
|
|
||||||
|
Hints for designers:
|
||||||
|
make start-maputnik # start Maputnik Editor + dynamic tile server [ see $(OMT_HOST):8088 ]
|
||||||
|
make stop-maputnik # stop Maputnik Editor + dynamic tile server
|
||||||
|
make start-postserve # start dynamic tile server [ see $(OMT_HOST):$(PPORT) ]
|
||||||
|
make stop-postserve # stop dynamic tile server
|
||||||
|
make start-tileserver # start maptiler/tileserver-gl [ see $(OMT_HOST):$(TPORT) ]
|
||||||
|
make stop-tileserver # stop maptiler/tileserver-gl
|
||||||
|
|
||||||
|
Hints for developers:
|
||||||
|
make # build source code
|
||||||
|
make bash # start openmaptiles-tools /bin/bash terminal
|
||||||
|
make generate-bbox-file # compute bounding box of a data file and store it in a file
|
||||||
|
make generate-devdoc # generate devdoc including graphs for all layers [./layers/...]
|
||||||
|
make generate-qa # statistics for a given layer's field
|
||||||
|
make generate-tiles-pg # generate vector tiles based on .env settings using PostGIS ST_MVT()
|
||||||
|
make generate-tiles # generate vector tiles based on .env settings using Mapnik (obsolete)
|
||||||
|
make generate-changed-tiles # Generate tiles changed by import-diff
|
||||||
|
make test-sql # run unit tests on the OpenMapTiles SQL schema
|
||||||
|
cat .env # list PG database and MIN_ZOOM and MAX_ZOOM information
|
||||||
|
cat quickstart.log # transcript of the last ./quickstart.sh run
|
||||||
|
make help # help about available commands
|
||||||
|
|
||||||
|
Hints for downloading & importing data:
|
||||||
|
make list-geofabrik # list actual geofabrik OSM extracts for download
|
||||||
|
make list-bbbike # list actual BBBike OSM extracts for download
|
||||||
|
make download area=albania # download OSM data from any source and create config file
|
||||||
|
make download-geofabrik area=albania # download OSM data from geofabrik.de and create config file
|
||||||
|
make download-osmfr area=asia/qatar # download OSM data from openstreetmap.fr and create config file
|
||||||
|
make download-bbbike area=Amsterdam # download OSM data from bbbike.org and create config file
|
||||||
|
make import-data # Import data from OpenStreetMapData, Natural Earth and OSM Lake Labels.
|
||||||
|
make import-osm # Import OSM data with the mapping rules from build/mapping.yaml
|
||||||
|
make import-diff # Import OSM updates from data/changes.osc.gz
|
||||||
|
make import-wikidata # Import labels from Wikidata
|
||||||
|
make import-sql # Import layers (run this after modifying layer SQL)
|
||||||
|
|
||||||
|
Hints for database management:
|
||||||
|
make psql # start PostgreSQL console
|
||||||
|
make psql-list-tables # list all PostgreSQL tables
|
||||||
|
make list-views # list PostgreSQL public schema views
|
||||||
|
make list-tables # list PostgreSQL public schema tables
|
||||||
|
make vacuum-db # PostgreSQL: VACUUM ANALYZE
|
||||||
|
make analyze-db # PostgreSQL: ANALYZE
|
||||||
|
make destroy-db # remove docker containers and PostgreSQL data volume
|
||||||
|
make start-db # start PostgreSQL, creating it if it doesn't exist
|
||||||
|
make start-db-preloaded # start PostgreSQL, creating data-prepopulated one if it doesn't exist
|
||||||
|
make stop-db # stop PostgreSQL database without destroying the data
|
||||||
|
|
||||||
|
Hints for Docker management:
|
||||||
|
make clean-unnecessary-docker # clean unnecessary docker image(s) and container(s)
|
||||||
|
make refresh-docker-images # refresh openmaptiles docker images from Docker HUB
|
||||||
|
make remove-docker-images # remove openmaptiles docker images
|
||||||
|
make list-docker-images # show a list of available docker images
|
||||||
|
==============================================================================
|
||||||
|
endef
|
||||||
|
export HELP_MESSAGE
|
||||||
|
|
||||||
|
#
|
||||||
|
# TARGETS
|
||||||
|
#
|
||||||
|
|
||||||
|
.PHONY: all
|
||||||
|
all: init-dirs build/openmaptiles.tm2source/data.yml build/mapping.yaml build-sql
|
||||||
|
|
||||||
|
.PHONY: help
|
||||||
|
help:
|
||||||
|
@echo "$$HELP_MESSAGE" | less
|
||||||
|
|
||||||
|
define win_fs_error
|
||||||
|
( \
|
||||||
|
echo "" ;\
|
||||||
|
echo "ERROR: Windows native filesystem" ;\
|
||||||
|
echo "" ;\
|
||||||
|
echo "Please avoid running OpenMapTiles in a Windows filesystem." ;\
|
||||||
|
echo "See https://github.com/openmaptiles/openmaptiles/issues/1095#issuecomment-817095465" ;\
|
||||||
|
echo "" ;\
|
||||||
|
exit 1 ;\
|
||||||
|
)
|
||||||
|
endef
|
||||||
|
|
||||||
|
.PHONY: init-dirs
|
||||||
|
init-dirs:
|
||||||
|
@mkdir -p build/sql/parallel
|
||||||
|
@mkdir -p build/openmaptiles.tm2source
|
||||||
|
@mkdir -p build/style
|
||||||
|
@mkdir -p data
|
||||||
|
@mkdir -p cache
|
||||||
|
@ ! ($(DOCKER_COMPOSE) 2>/dev/null run $(DC_OPTS) openmaptiles-tools df --output=fstype /tileset| grep -q 9p) < /dev/null || ($(win_fs_error))
|
||||||
|
|
||||||
|
build/openmaptiles.tm2source/data.yml: init-dirs
|
||||||
|
ifeq (,$(wildcard build/openmaptiles.tm2source/data.yml))
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
||||||
|
'generate-tm2source $(TILESET_FILE) > $@'
|
||||||
|
endif
|
||||||
|
|
||||||
|
build/mapping.yaml: init-dirs
|
||||||
|
ifeq (,$(wildcard build/mapping.yaml))
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
||||||
|
'generate-imposm3 $(TILESET_FILE) > $@'
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: build-sql
|
||||||
|
build-sql: init-dirs
|
||||||
|
ifeq (,$(wildcard build/sql/run_last.sql))
|
||||||
|
@mkdir -p build/sql/parallel
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c \
|
||||||
|
'generate-sql $(TILESET_FILE) --dir ./build/sql \
|
||||||
|
&& generate-sqltomvt $(TILESET_FILE) \
|
||||||
|
--key --gzip --postgis-ver 3.3.4 \
|
||||||
|
--function --fname=getmvt >> ./build/sql/run_last.sql'
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: build-sprite
|
||||||
|
build-sprite: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c 'spreet /style/icons build/style/sprite && \
|
||||||
|
spreet --retina /style/icons build/style/sprite@2x'
|
||||||
|
|
||||||
|
.PHONY: build-style
|
||||||
|
build-style: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c 'style-tools recompose $(TILESET_FILE) $(STYLE_FILE) \
|
||||||
|
$(STYLE_HEADER_FILE) && \
|
||||||
|
spreet /style/icons build/style/sprite && spreet --retina /style/icons build/style/sprite@2x'
|
||||||
|
|
||||||
|
.PHONY: download-fonts
|
||||||
|
download-fonts:
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash -c '[ ! -d "/export/fonts" ] && mkdir /export/fonts && \
|
||||||
|
echo "Downloading fonts..." && wget -qO /export/noto-sans.zip --show-progress \
|
||||||
|
https://github.com/openmaptiles/fonts/releases/download/v2.0/noto-sans.zip && \
|
||||||
|
echo "Unzipping fonts..." && unzip -q /export/noto-sans.zip -d /export/fonts && rm /export/noto-sans.zip || \
|
||||||
|
echo "Fonts already exist."'
|
||||||
|
|
||||||
|
.PHONY: clean
|
||||||
|
clean: clean-test-data
|
||||||
|
rm -rf build
|
||||||
|
|
||||||
|
clean-test-data:
|
||||||
|
rm -rf data/changes.state.txt
|
||||||
|
rm -rf data/last.state.txt
|
||||||
|
rm -rf data/changes.repl.json
|
||||||
|
|
||||||
|
.PHONY: destroy-db
|
||||||
|
DOCKER_PROJECT = $(shell echo $(DC_PROJECT) | tr A-Z a-z | tr -cd '[:alnum:]')
|
||||||
|
destroy-db:
|
||||||
|
$(DOCKER_COMPOSE) down -v --remove-orphans
|
||||||
|
$(DOCKER_COMPOSE) rm -fv
|
||||||
|
docker volume ls -q -f "name=^$(DOCKER_PROJECT)_" | $(XARGS) docker volume rm
|
||||||
|
rm -rf cache
|
||||||
|
mkdir cache
|
||||||
|
|
||||||
|
.PHONY: start-db-nowait
|
||||||
|
start-db-nowait: init-dirs
|
||||||
|
@echo "Starting postgres docker compose target using $${POSTGIS_IMAGE:-default} image (no recreate if exists)" && \
|
||||||
|
$(DOCKER_COMPOSE) up --no-recreate -d postgres
|
||||||
|
|
||||||
|
.PHONY: start-db
|
||||||
|
start-db: start-db-nowait
|
||||||
|
@echo "Wait for PostgreSQL to start..."
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools pgwait
|
||||||
|
|
||||||
|
# Wrap start-db target but use the preloaded image
|
||||||
|
.PHONY: start-db-preloaded
|
||||||
|
start-db-preloaded: export POSTGIS_IMAGE=openmaptiles/postgis-preloaded
|
||||||
|
start-db-preloaded: export COMPOSE_HTTP_TIMEOUT=180
|
||||||
|
start-db-preloaded: start-db
|
||||||
|
|
||||||
|
.PHONY: stop-db
|
||||||
|
stop-db:
|
||||||
|
@echo "Stopping PostgreSQL..."
|
||||||
|
$(DOCKER_COMPOSE) stop postgres
|
||||||
|
|
||||||
|
.PHONY: list-geofabrik
|
||||||
|
list-geofabrik: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm list geofabrik
|
||||||
|
|
||||||
|
.PHONY: list-bbbike
|
||||||
|
list-bbbike: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm list bbbike
|
||||||
|
|
||||||
|
#
|
||||||
|
# download, download-geofabrik, download-osmfr, and download-bbbike are handled here
|
||||||
|
# The --imposm-cfg will fail for some of the sources, but we ignore that error -- only needed for diff mode
|
||||||
|
#
|
||||||
|
OSM_SERVERS := geofabrik osmfr bbbike
|
||||||
|
ALL_DOWNLOADS := $(addprefix download-,$(OSM_SERVERS)) download
|
||||||
|
OSM_SERVER=$(patsubst download,,$(patsubst download-%,%,$@))
|
||||||
|
.PHONY: $(ALL_DOWNLOADS)
|
||||||
|
$(ALL_DOWNLOADS): init-dirs
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
ifneq ($(url),)
|
||||||
|
$(if $(OSM_SERVER),$(error url parameter can only be used with non-specific download target:$(newline) make download area=$(area) url="$(url)"$(newline)))
|
||||||
|
endif
|
||||||
|
ifeq (,$(wildcard $(PBF_FILE)))
|
||||||
|
ifeq ($(DIFF_MODE),true)
|
||||||
|
@echo "Downloading $(DOWNLOAD_AREA) with replication support into $(PBF_FILE) and $(IMPOSM_CONFIG_FILE) from $(if $(OSM_SERVER),$(OSM_SERVER),any source)"
|
||||||
|
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm $(OSM_SERVER) "$(DOWNLOAD_AREA)" \
|
||||||
|
--imposm-cfg "$(IMPOSM_CONFIG_FILE)" \
|
||||||
|
--bbox "$(AREA_BBOX_FILE)" \
|
||||||
|
--output "$(PBF_FILE)"
|
||||||
|
else
|
||||||
|
@echo "Downloading $(DOWNLOAD_AREA) into $(PBF_FILE) from $(if $(OSM_SERVER),$(OSM_SERVER),any source)"
|
||||||
|
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm $(OSM_SERVER) "$(DOWNLOAD_AREA)" \
|
||||||
|
--bbox "$(AREA_BBOX_FILE)" \
|
||||||
|
--output "$(PBF_FILE)"
|
||||||
|
endif
|
||||||
|
@echo ""
|
||||||
|
else
|
||||||
|
ifeq ($(DIFF_MODE),true)
|
||||||
|
ifeq (,$(wildcard $(IMPOSM_CONFIG_FILE)))
|
||||||
|
$(error \
|
||||||
|
$(newline) Data files $(PBF_FILE) already exists, but $(IMPOSM_CONFIG_FILE) does not. \
|
||||||
|
$(newline) You probably downloaded the data file before setting DIFF_MODE=true. \
|
||||||
|
$(newline) You can delete the data file $(PBF_FILE) and re-run make download \
|
||||||
|
$(newline) to re-download and generate config, or manually create $(IMPOSM_CONFIG_FILE) \
|
||||||
|
$(newline) See example https://github.com/openmaptiles/openmaptiles-tools/blob/v5.2/bin/config/repl_config.json \
|
||||||
|
$(newline))
|
||||||
|
else
|
||||||
|
@echo "Data files $(PBF_FILE) and replication config $(IMPOSM_CONFIG_FILE) already exists, skipping the download."
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
@echo "Data files $(PBF_FILE) already exists, skipping the download."
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: generate-bbox-file
|
||||||
|
generate-bbox-file:
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
ifeq (,$(wildcard $(AREA_BBOX_FILE)))
|
||||||
|
@$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools download-osm bbox "$(PBF_FILE)" "$(AREA_BBOX_FILE)"
|
||||||
|
else
|
||||||
|
@echo "Configuration file $(AREA_BBOX_FILE) already exists, no need to regenerate. BBOX=$(BBOX)"
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: psql
|
||||||
|
psql: start-db-nowait
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && psql.sh'
|
||||||
|
|
||||||
|
# Special cache handling for Docker Toolbox on Windows
|
||||||
|
ifeq ($(MSYSTEM),MINGW64)
|
||||||
|
DC_CONFIG_CACHE := -f docker-compose.yml -f docker-compose-$(MSYSTEM).yml
|
||||||
|
DC_OPTS_CACHE := $(filter-out --user=%,$(DC_OPTS))
|
||||||
|
else
|
||||||
|
DC_OPTS_CACHE := $(DC_OPTS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: import-osm
|
||||||
|
import-osm: all start-db-nowait
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-osm $(PBF_FILE)'
|
||||||
|
|
||||||
|
.PHONY: start-update-osm
|
||||||
|
start-update-osm: start-db
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) up -d update-osm
|
||||||
|
|
||||||
|
.PHONY: stop-update-osm
|
||||||
|
stop-update-osm:
|
||||||
|
$(DOCKER_COMPOSE) stop update-osm
|
||||||
|
|
||||||
|
.PHONY: import-diff
|
||||||
|
import-diff: start-db-nowait
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-diff'
|
||||||
|
|
||||||
|
.PHONY: import-data
|
||||||
|
import-data: start-db
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) import-data
|
||||||
|
|
||||||
|
.PHONY: import-sql
|
||||||
|
import-sql: all start-db-nowait
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-sql' | \
|
||||||
|
awk -v s=": WARNING:" '1{print; fflush()} $$0~s{print "\n*** WARNING detected, aborting"; exit(1)}' | \
|
||||||
|
awk '1{print; fflush()} $$0~".*ERROR" {txt=$$0} END{ if(txt){print "\n*** ERROR detected, aborting:"; print txt; exit(1)} }'
|
||||||
|
|
||||||
|
.PHONY: generate-tiles
|
||||||
|
generate-tiles: all start-db
|
||||||
|
@echo "WARNING: This Mapnik-based method of tile generation is obsolete. Use generate-tiles-pg instead."
|
||||||
|
@echo "Generating tiles into $(MBTILES_LOCAL_FILE) (will delete if already exists)..."
|
||||||
|
@rm -rf "$(MBTILES_LOCAL_FILE)"
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) generate-vectortiles
|
||||||
|
@echo "Updating generated tile metadata ..."
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
||||||
|
mbtiles-tools meta-generate "$(MBTILES_LOCAL_FILE)" $(TILESET_FILE) --auto-minmax --show-ranges
|
||||||
|
|
||||||
|
.PHONY: generate-tiles-pg
|
||||||
|
generate-tiles-pg: all start-db
|
||||||
|
@echo "Generating tiles into $(MBTILES_LOCAL_FILE) (will delete if already exists) using PostGIS ST_MVT()..."
|
||||||
|
@rm -rf "$(MBTILES_LOCAL_FILE)"
|
||||||
|
# For some reason Ctrl+C doesn't work here without the -T. Must be pressed twice to stop.
|
||||||
|
$(DOCKER_COMPOSE) run -T $(DC_OPTS) openmaptiles-tools generate-tiles
|
||||||
|
@echo "Updating generated tile metadata ..."
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
||||||
|
mbtiles-tools meta-generate "$(MBTILES_LOCAL_FILE)" $(TILESET_FILE) --auto-minmax --show-ranges
|
||||||
|
|
||||||
|
.PHONY: data/tiles.txt
|
||||||
|
data/tiles.txt:
|
||||||
|
find ./data -name "*.tiles" -exec cat {} \; -exec rm {} \; | \
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
||||||
|
tile_multiplier $(MIN_ZOOM) $(MAX_ZOOM) >> data/tiles.txt
|
||||||
|
|
||||||
|
.PHONY: generate-changed-tiles
|
||||||
|
generate-changed-tiles: data/tiles.txt
|
||||||
|
# Re-generating updated tiles, if needed
|
||||||
|
if [ -s data/tiles.txt ] ; then \
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools refresh-views; \
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) -e LIST_FILE=data/tiles.txt openmaptiles-tools generate-tiles; \
|
||||||
|
rm data/tiles.txt; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
.PHONY: start-tileserver
|
||||||
|
start-tileserver: init-dirs build-style download-fonts
|
||||||
|
@echo " "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo "* "
|
||||||
|
@echo "* Download/refresh maptiler/tileserver-gl docker image"
|
||||||
|
@echo "* see documentation: https://github.com/maptiler/tileserver-gl"
|
||||||
|
@echo "* "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo " "
|
||||||
|
$(DOCKER_COMPOSE_COMMAND) pull tileserver-gl
|
||||||
|
@echo " "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo "* "
|
||||||
|
@echo "* Start maptiler/tileserver-gl "
|
||||||
|
@echo "* ----------------------------> check $(OMT_HOST):$(TPORT) "
|
||||||
|
@echo "* "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo " "
|
||||||
|
$(DOCKER_COMPOSE) up -d tileserver-gl
|
||||||
|
|
||||||
|
.PHONY: stop-tileserver
|
||||||
|
stop-tileserver:
|
||||||
|
$(DOCKER_COMPOSE) stop tileserver-gl
|
||||||
|
|
||||||
|
.PHONY: start-postserve
|
||||||
|
start-postserve: start-db
|
||||||
|
@echo " "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo "* "
|
||||||
|
@echo "* Bring up postserve at $(OMT_HOST):$(PPORT)"
|
||||||
|
@echo "* --> can view it locally (use make start-maputnik)"
|
||||||
|
@echo "* --> or can use https://maputnik.github.io/editor"
|
||||||
|
@echo "* "
|
||||||
|
@echo "* set data source / TileJSON URL to $(OMT_HOST):$(PPORT)"
|
||||||
|
@echo "* "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo " "
|
||||||
|
$(DOCKER_COMPOSE) up -d postserve
|
||||||
|
|
||||||
|
.PHONY: stop-postserve
|
||||||
|
stop-postserve:
|
||||||
|
$(DOCKER_COMPOSE) stop postserve
|
||||||
|
|
||||||
|
.PHONY: start-maputnik
|
||||||
|
start-maputnik: stop-maputnik start-postserve
|
||||||
|
@echo " "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo "* "
|
||||||
|
@echo "* Start maputnik/editor "
|
||||||
|
@echo "* ---> go to $(OMT_HOST):8088 "
|
||||||
|
@echo "* ---> set data source / TileJSON URL to $(OMT_HOST):$(PPORT)"
|
||||||
|
@echo "* "
|
||||||
|
@echo "***********************************************************"
|
||||||
|
@echo " "
|
||||||
|
$(DOCKER_COMPOSE) up -d maputnik_editor
|
||||||
|
|
||||||
|
.PHONY: stop-maputnik
|
||||||
|
stop-maputnik:
|
||||||
|
-$(DOCKER_COMPOSE) stop maputnik_editor
|
||||||
|
|
||||||
|
# STAT_FUNCTION=frequency|toplength|variance
|
||||||
|
.PHONY: generate-qa
|
||||||
|
generate-qa: all start-db-nowait
|
||||||
|
@echo " "
|
||||||
|
@echo "e.g. make generate-qa STAT_FUNCTION=frequency LAYER=transportation ATTRIBUTE=class"
|
||||||
|
@echo " "
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools \
|
||||||
|
layer-stats $(STAT_FUNCTION) $(TILESET_FILE) $(LAYER) $(ATTRIBUTE) -m 0 -n 14 -v
|
||||||
|
|
||||||
|
# generate all etl and mapping graphs
|
||||||
|
.PHONY: generate-devdoc
|
||||||
|
generate-devdoc: init-dirs
|
||||||
|
mkdir -p ./build/devdoc && \
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c \
|
||||||
|
'generate-etlgraph $(TILESET_FILE) $(GRAPH_PARAMS) && \
|
||||||
|
generate-mapping-graph $(TILESET_FILE) $(GRAPH_PARAMS)'
|
||||||
|
|
||||||
|
.PHONY: bash
|
||||||
|
bash: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools bash
|
||||||
|
|
||||||
|
.PHONY: import-wikidata
|
||||||
|
import-wikidata: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools import-wikidata --cache /cache/wikidata-cache.json $(TILESET_FILE)
|
||||||
|
|
||||||
|
.PHONY: reset-db-stats
|
||||||
|
reset-db-stats: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -P pager=off -c 'SELECT pg_stat_statements_reset();'
|
||||||
|
|
||||||
|
.PHONY: list-views
|
||||||
|
list-views: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
||||||
|
-c "select viewname from pg_views where schemaname='public' order by viewname;"
|
||||||
|
|
||||||
|
.PHONY: list-tables
|
||||||
|
list-tables: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -A -F"," -P pager=off -P footer=off \
|
||||||
|
-c "select tablename from pg_tables where schemaname='public' order by tablename;"
|
||||||
|
|
||||||
|
.PHONY: psql-list-tables
|
||||||
|
psql-list-tables: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -P pager=off -c "\d+"
|
||||||
|
|
||||||
|
.PHONY: vacuum-db
|
||||||
|
vacuum-db: init-dirs
|
||||||
|
@echo "Start - postgresql: VACUUM ANALYZE VERBOSE;"
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -P pager=off -c 'VACUUM ANALYZE VERBOSE;'
|
||||||
|
|
||||||
|
.PHONY: analyze-db
|
||||||
|
analyze-db: init-dirs
|
||||||
|
@echo "Start - postgresql: ANALYZE VERBOSE;"
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools psql.sh -v ON_ERROR_STOP=1 -P pager=off -c 'ANALYZE VERBOSE;'
|
||||||
|
|
||||||
|
.PHONY: list-docker-images
|
||||||
|
list-docker-images:
|
||||||
|
docker images | grep openmaptiles
|
||||||
|
|
||||||
|
.PHONY: refresh-docker-images
|
||||||
|
refresh-docker-images: init-dirs
|
||||||
|
ifneq ($(NO_REFRESH),)
|
||||||
|
@echo "Skipping docker image refresh"
|
||||||
|
else
|
||||||
|
@echo ""
|
||||||
|
@echo "Refreshing docker images... Use NO_REFRESH=1 to skip."
|
||||||
|
ifneq ($(USE_PRELOADED_IMAGE),)
|
||||||
|
POSTGIS_IMAGE=openmaptiles/postgis-preloaded \
|
||||||
|
$(DOCKER_COMPOSE_COMMAND) pull --ignore-pull-failures $(QUIET_FLAG) openmaptiles-tools generate-vectortiles postgres
|
||||||
|
else
|
||||||
|
$(DOCKER_COMPOSE_COMMAND) pull --ignore-pull-failures $(QUIET_FLAG) openmaptiles-tools generate-vectortiles postgres import-data
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
.PHONY: remove-docker-images
|
||||||
|
remove-docker-images:
|
||||||
|
@echo "Deleting all openmaptiles related docker image(s)..."
|
||||||
|
@$(DOCKER_COMPOSE) down
|
||||||
|
@docker images "openmaptiles/*" -q | $(XARGS) docker rmi -f
|
||||||
|
@docker images "maputnik/editor" -q | $(XARGS) docker rmi -f
|
||||||
|
@docker images "maptiler/tileserver-gl" -q | $(XARGS) docker rmi -f
|
||||||
|
|
||||||
|
.PHONY: clean-unnecessary-docker
|
||||||
|
clean-unnecessary-docker:
|
||||||
|
@echo "Deleting unnecessary container(s)..."
|
||||||
|
@docker ps -a -q --filter "status=exited" | $(XARGS) docker rm
|
||||||
|
@echo "Deleting unnecessary image(s)..."
|
||||||
|
@docker images | awk -F" " '/<none>/{print $$3}' | $(XARGS) docker rmi
|
||||||
|
|
||||||
|
.PHONY: test-perf-null
|
||||||
|
test-perf-null: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools test-perf $(TILESET_FILE) --test null --no-color
|
||||||
|
|
||||||
|
.PHONY: build-test-pbf
|
||||||
|
build-test-pbf: init-dirs
|
||||||
|
$(DOCKER_COMPOSE_COMMAND) run $(DC_OPTS) openmaptiles-tools /tileset/.github/workflows/build-test-data.sh
|
||||||
|
|
||||||
|
.PHONY: debug
|
||||||
|
debug: ## Use this target when developing Makefile itself to verify loaded environment variables
|
||||||
|
@$(assert_area_is_given)
|
||||||
|
@echo file_exists = $(wildcard $(AREA_BBOX_FILE))
|
||||||
|
@echo AREA_BBOX_FILE = $(AREA_BBOX_FILE) , $$AREA_ENV_FILE
|
||||||
|
@echo BBOX = $(BBOX) , $$BBOX
|
||||||
|
@echo MIN_ZOOM = $(MIN_ZOOM) , $$MIN_ZOOM
|
||||||
|
@echo MAX_ZOOM = $(MAX_ZOOM) , $$MAX_ZOOM
|
||||||
|
|
||||||
|
build/import-tests.osm.pbf: init-dirs
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'osmconvert tests/import/*.osm -o=build/import-tests.osm.pbf'
|
||||||
|
|
||||||
|
data/changes.state.txt:
|
||||||
|
cp -f tests/changes.state.txt data/
|
||||||
|
|
||||||
|
data/last.state.txt:
|
||||||
|
cp -f tests/last.state.txt data/
|
||||||
|
|
||||||
|
data/changes.repl.json:
|
||||||
|
cp -f tests/changes.repl.json data/
|
||||||
|
|
||||||
|
data/changes.osc.gz: init-dirs
|
||||||
|
@echo " UPDATE unit test data..."
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'osmconvert tests/update/*.osc --merge-versions -o=data/changes.osc && gzip -f data/changes.osc'
|
||||||
|
|
||||||
|
test-sql: clean refresh-docker-images destroy-db start-db-nowait build/import-tests.osm.pbf data/changes.state.txt data/last.state.txt data/changes.repl.json build/mapping.yaml data/changes.osc.gz build/openmaptiles.tm2source/data.yml build/mapping.yaml build-sql
|
||||||
|
$(eval area := changes)
|
||||||
|
|
||||||
|
@echo "Load IMPORT test data"
|
||||||
|
sed -ir "s/^[#]*\s*MAX_ZOOM=.*/MAX_ZOOM=14/" .env
|
||||||
|
sed -ir "s/^[#]*\s*DIFF_MODE=.*/DIFF_MODE=false/" .env
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-osm build/import-tests.osm.pbf'
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) import-data
|
||||||
|
|
||||||
|
@echo "Apply OpenMapTiles SQL schema to test data @ Zoom 14..."
|
||||||
|
$(DOCKER_COMPOSE) run $(DC_OPTS) openmaptiles-tools sh -c 'pgwait && import-sql' | \
|
||||||
|
awk -v s=": WARNING:" '1{print; fflush()} $$0~s{print "\n*** WARNING detected, aborting"; exit(1)}' | \
|
||||||
|
awk '1{print; fflush()} $$0~".*ERROR" {txt=$$0} END{ if(txt){print "\n*** ERROR detected, aborting:"; print txt; exit(1)} }'
|
||||||
|
|
||||||
|
@echo "Test SQL output for Import Test Data"
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && psql.sh < tests/test-post-import.sql' 2>&1 | \
|
||||||
|
awk -v s="ERROR:" '1{print; fflush()} $$0~s{print "*** ERROR detected, aborting"; exit(1)}'
|
||||||
|
|
||||||
|
@echo "Run UPDATE process on test data..."
|
||||||
|
sed -ir "s/^[#]*\s*DIFF_MODE=.*/DIFF_MODE=true/" .env
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && import-diff'
|
||||||
|
|
||||||
|
@echo "Test SQL output for Update Test Data"
|
||||||
|
$(DOCKER_COMPOSE) $(DC_CONFIG_CACHE) run $(DC_OPTS_CACHE) openmaptiles-tools sh -c 'pgwait && psql.sh < tests/test-post-update.sql' 2>&1 | \
|
||||||
|
awk -v s="ERROR:" '1{print; fflush()} $$0~s{print "*** ERROR detected, aborting"; exit(1)}'
|
3
README.md
Normal file
3
README.md
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
# vfosnar map tiles
|
||||||
|
|
||||||
|
Fork of OpenMapTiles to generate data missing from standard OMT
|
11
docker-compose-MINGW64.yml
Normal file
11
docker-compose-MINGW64.yml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
# This version must match the MAKE_DC_VERSION in docker-compose.yml
|
||||||
|
version: "3"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
cache:
|
||||||
|
|
||||||
|
services:
|
||||||
|
|
||||||
|
openmaptiles-tools:
|
||||||
|
volumes:
|
||||||
|
- cache:/cache
|
143
docker-compose.yml
Normal file
143
docker-compose.yml
Normal file
|
@ -0,0 +1,143 @@
|
||||||
|
# This version must match the MAKE_DC_VERSION value below
|
||||||
|
version: "3"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
pgdata:
|
||||||
|
|
||||||
|
networks:
|
||||||
|
postgres:
|
||||||
|
driver: bridge
|
||||||
|
|
||||||
|
services:
|
||||||
|
|
||||||
|
postgres:
|
||||||
|
image: "${POSTGIS_IMAGE:-openmaptiles/postgis}:${TOOLS_VERSION}"
|
||||||
|
# Use "command: postgres -c jit=off" for PostgreSQL 11+ because of slow large MVT query processing
|
||||||
|
# Use "shm_size: 512m" if you want to prevent a possible 'No space left on device' during 'make generate-tiles-pg'
|
||||||
|
volumes:
|
||||||
|
- pgdata:/var/lib/postgresql/data
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
ports:
|
||||||
|
- "${PGPORT:-5432}:${PGPORT:-5432}"
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
# postgress container uses old variable names
|
||||||
|
POSTGRES_DB: ${PGDATABASE:-openmaptiles}
|
||||||
|
POSTGRES_USER: ${PGUSER:-openmaptiles}
|
||||||
|
POSTGRES_PASSWORD: ${PGPASSWORD:-openmaptiles}
|
||||||
|
PGPORT: ${PGPORT:-5432}
|
||||||
|
|
||||||
|
import-data:
|
||||||
|
image: "openmaptiles/import-data:${TOOLS_VERSION}"
|
||||||
|
env_file: .env
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
|
||||||
|
openmaptiles-tools: &openmaptiles-tools
|
||||||
|
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
# Must match the version of this file (first line)
|
||||||
|
# download-osm will use it when generating a composer file
|
||||||
|
MAKE_DC_VERSION: "3"
|
||||||
|
# Allow DIFF_MODE, MIN_ZOOM, and MAX_ZOOM to be overwritten from shell
|
||||||
|
DIFF_MODE: ${DIFF_MODE}
|
||||||
|
MIN_ZOOM: ${MIN_ZOOM}
|
||||||
|
MAX_ZOOM: ${MAX_ZOOM}
|
||||||
|
#Provide BBOX from *.bbox file if exists, else from .env
|
||||||
|
BBOX: ${BBOX}
|
||||||
|
# Imposm configuration file describes how to load updates when enabled
|
||||||
|
IMPOSM_CONFIG_FILE: ${IMPOSM_CONFIG_FILE}
|
||||||
|
# Control import-sql processes
|
||||||
|
MAX_PARALLEL_PSQL: ${MAX_PARALLEL_PSQL}
|
||||||
|
PGDATABASE: ${PGDATABASE:-openmaptiles}
|
||||||
|
PGUSER: ${PGUSER:-openmaptiles}
|
||||||
|
PGPASSWORD: ${PGPASSWORD:-openmaptiles}
|
||||||
|
PGPORT: ${PGPORT:-5432}
|
||||||
|
MBTILES_FILE: ${MBTILES_FILE}
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
volumes:
|
||||||
|
- .:/tileset
|
||||||
|
- ./data:/import
|
||||||
|
- ./data:/export
|
||||||
|
- ./build/sql:/sql
|
||||||
|
- ./build:/mapping
|
||||||
|
- ./cache:/cache
|
||||||
|
- ./style:/style
|
||||||
|
|
||||||
|
update-osm:
|
||||||
|
<<: *openmaptiles-tools
|
||||||
|
command: import-update
|
||||||
|
|
||||||
|
generate-changed-vectortiles:
|
||||||
|
image: "openmaptiles/generate-vectortiles:${TOOLS_VERSION}"
|
||||||
|
command: ./export-list.sh
|
||||||
|
volumes:
|
||||||
|
- ./data:/export
|
||||||
|
- ./build/openmaptiles.tm2source:/tm2source
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
MBTILES_NAME: ${MBTILES_FILE}
|
||||||
|
# Control tilelive-copy threads
|
||||||
|
COPY_CONCURRENCY: ${COPY_CONCURRENCY}
|
||||||
|
PGDATABASE: ${PGDATABASE:-openmaptiles}
|
||||||
|
PGUSER: ${PGUSER:-openmaptiles}
|
||||||
|
PGPASSWORD: ${PGPASSWORD:-openmaptiles}
|
||||||
|
PGPORT: ${PGPORT:-5432}
|
||||||
|
|
||||||
|
generate-vectortiles:
|
||||||
|
image: "openmaptiles/generate-vectortiles:${TOOLS_VERSION}"
|
||||||
|
volumes:
|
||||||
|
- ./data:/export
|
||||||
|
- ./build/openmaptiles.tm2source:/tm2source
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
MBTILES_NAME: ${MBTILES_FILE}
|
||||||
|
BBOX: ${BBOX}
|
||||||
|
MIN_ZOOM: ${MIN_ZOOM}
|
||||||
|
MAX_ZOOM: ${MAX_ZOOM}
|
||||||
|
# Control tilelive-copy threads
|
||||||
|
COPY_CONCURRENCY: ${COPY_CONCURRENCY}
|
||||||
|
#
|
||||||
|
PGDATABASE: ${PGDATABASE:-openmaptiles}
|
||||||
|
PGUSER: ${PGUSER:-openmaptiles}
|
||||||
|
PGPASSWORD: ${PGPASSWORD:-openmaptiles}
|
||||||
|
PGPORT: ${PGPORT:-5432}
|
||||||
|
|
||||||
|
postserve:
|
||||||
|
image: "openmaptiles/openmaptiles-tools:${TOOLS_VERSION}"
|
||||||
|
command: "postserve ${TILESET_FILE} --verbose --serve=${OMT_HOST:-http://localhost}:${PPORT:-8090}"
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
TILESET_FILE: ${TILESET_FILE}
|
||||||
|
networks:
|
||||||
|
- postgres
|
||||||
|
ports:
|
||||||
|
- "${PPORT:-8090}:${PPORT:-8090}"
|
||||||
|
volumes:
|
||||||
|
- .:/tileset
|
||||||
|
|
||||||
|
maputnik_editor:
|
||||||
|
image: "maputnik/editor"
|
||||||
|
ports:
|
||||||
|
- "8088:8888"
|
||||||
|
|
||||||
|
tileserver-gl:
|
||||||
|
image: "maptiler/tileserver-gl:latest"
|
||||||
|
command:
|
||||||
|
- --port
|
||||||
|
- "${TPORT:-8080}"
|
||||||
|
- --config
|
||||||
|
- "/style/config.json"
|
||||||
|
ports:
|
||||||
|
- "${TPORT:-8080}:${TPORT:-8080}"
|
||||||
|
volumes:
|
||||||
|
- ./data:/data
|
||||||
|
- ./style:/style
|
||||||
|
- ./build:/build
|
37
integrity.sh
Executable file
37
integrity.sh
Executable file
|
@ -0,0 +1,37 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# A script to run the "integrity" continuous integration script.
|
||||||
|
|
||||||
|
area=monaco
|
||||||
|
echo MIN_ZOOM=0 >> .env
|
||||||
|
echo MAX_ZOOM=14 >> .env
|
||||||
|
./quickstart.sh $area
|
||||||
|
export TEST_MODE=yes
|
||||||
|
make generate-devdoc
|
||||||
|
area=europe/monaco
|
||||||
|
echo DIFF_MODE=true >> .env
|
||||||
|
|
||||||
|
# Cleanup
|
||||||
|
rm -fr data build cache
|
||||||
|
# Create data/$area.repl.json
|
||||||
|
make download-geofabrik area=$area
|
||||||
|
# Download 2+ month old data
|
||||||
|
export old_date=$(date --date="$(date +%Y-%m-15) -2 month" +'%y%m01')
|
||||||
|
echo Downloading $old_date extract of $area
|
||||||
|
docker-compose run --rm --user=$(id -u):$(id -g) openmaptiles-tools sh -c "wget -O data/$area.osm.pbf http://download.geofabrik.de/$area-$old_date.osm.pbf"
|
||||||
|
# Initial import and tile generation
|
||||||
|
./quickstart.sh $area
|
||||||
|
sleep 2
|
||||||
|
echo Downloading updates
|
||||||
|
# Loop to recover from potential "ERROR 429: Too Many Requests"
|
||||||
|
docker-compose run --rm --user=$(id -u):$(id -g) openmaptiles-tools sh -c "
|
||||||
|
while ! osmupdate --keep-tempfiles --base-url=$(sed -n 's/ *\"replication_url\": //p' data/$area.repl.json) data/$area.osm.pbf data/changes.osc.gz ; do
|
||||||
|
sleep 2;
|
||||||
|
echo Sleeping...;
|
||||||
|
sleep 630;
|
||||||
|
done"
|
||||||
|
echo Downloading updates completed
|
||||||
|
echo Importing updates
|
||||||
|
make import-diff
|
||||||
|
echo Generating new tiles
|
||||||
|
make generate-tiles-pg
|
24
layers/exploration/exploration.yaml
Normal file
24
layers/exploration/exploration.yaml
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
layer:
|
||||||
|
id: "exploration"
|
||||||
|
description: exploration POIs
|
||||||
|
buffer_size: 4
|
||||||
|
srs: +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over
|
||||||
|
fields:
|
||||||
|
class:
|
||||||
|
subclass:
|
||||||
|
name:
|
||||||
|
description:
|
||||||
|
website:
|
||||||
|
wikidata:
|
||||||
|
wikipedia:
|
||||||
|
inscription:
|
||||||
|
memorial:
|
||||||
|
datasource:
|
||||||
|
geometry_field: geometry
|
||||||
|
srid: 900913
|
||||||
|
query: (SELECT geometry, class, subclass, name, description, website, wikidata, wikipedia, inscription, memorial FROM layer_exploration(!bbox!, z(!scale_denominator!))) AS t
|
||||||
|
schema:
|
||||||
|
- ./layer.sql
|
||||||
|
datasources:
|
||||||
|
- type: imposm3
|
||||||
|
mapping_file: ./mapping.yaml
|
6
layers/exploration/layer.sql
Normal file
6
layers/exploration/layer.sql
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
CREATE OR REPLACE FUNCTION layer_exploration(bbox geometry, zoom_level int)
|
||||||
|
RETURNS TABLE(osm_id bigint, geometry geometry, class text, subclass text, name text, description text, website text, wikidata text, wikipedia text, inscription text, memorial text) AS $$
|
||||||
|
SELECT osm_id, geometry, class, subclass, NULLIF(name, '') AS name, NULLIF(description, '') AS description, NULLIF(website, '') AS website, NULLIF(wikidata, '') AS wikidata, NULLIF(wikipedia, '') AS wikipedia, NULLIF(inscription, '') AS inscription, NULLIF(memorial, '') AS memorial
|
||||||
|
FROM osm_exploration_point
|
||||||
|
WHERE zoom_level >= 14 AND geometry && bbox;
|
||||||
|
$$ LANGUAGE SQL IMMUTABLE;
|
51
layers/exploration/mapping.yaml
Normal file
51
layers/exploration/mapping.yaml
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
tables:
|
||||||
|
# etldoc: imposm3 -> osm_exploration_point
|
||||||
|
exploration_point:
|
||||||
|
type: point
|
||||||
|
fields:
|
||||||
|
- name: osm_id
|
||||||
|
type: id
|
||||||
|
- name: geometry
|
||||||
|
type: geometry
|
||||||
|
- name: class
|
||||||
|
type: mapping_key
|
||||||
|
- name: subclass
|
||||||
|
type: mapping_value
|
||||||
|
- key: name
|
||||||
|
name: name
|
||||||
|
type: string
|
||||||
|
- key: description
|
||||||
|
name: description
|
||||||
|
type: string
|
||||||
|
- key: website
|
||||||
|
name: website
|
||||||
|
type: string
|
||||||
|
- key: wikidata
|
||||||
|
name: wikidata
|
||||||
|
type: string
|
||||||
|
- key: wikipedia
|
||||||
|
name: wikipedia
|
||||||
|
type: string
|
||||||
|
- key: inscription
|
||||||
|
name: inscription
|
||||||
|
type: string
|
||||||
|
- key: memorial
|
||||||
|
name: memorial
|
||||||
|
type: string
|
||||||
|
mapping:
|
||||||
|
historic:
|
||||||
|
- castle
|
||||||
|
- memorial
|
||||||
|
- monument
|
||||||
|
- ruins
|
||||||
|
military:
|
||||||
|
- bunker
|
||||||
|
tourism:
|
||||||
|
- artwork
|
||||||
|
- attraction
|
||||||
|
- viewpoint
|
||||||
|
information:
|
||||||
|
- board
|
||||||
|
- map
|
||||||
|
- tactile_map
|
||||||
|
- tactile_model
|
17
layers/kct/kct.yaml
Normal file
17
layers/kct/kct.yaml
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
layer:
|
||||||
|
id: "kct"
|
||||||
|
description: kct
|
||||||
|
buffer_size: 4
|
||||||
|
srs: +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over
|
||||||
|
fields:
|
||||||
|
name:
|
||||||
|
waycolor:
|
||||||
|
datasource:
|
||||||
|
geometry_field: geometry
|
||||||
|
srid: 900913
|
||||||
|
query: (SELECT geometry, name, waycolor FROM layer_kct(!bbox!, z(!scale_denominator!))) AS t
|
||||||
|
schema:
|
||||||
|
- ./layer.sql
|
||||||
|
datasources:
|
||||||
|
- type: imposm3
|
||||||
|
mapping_file: ./mapping.yaml
|
6
layers/kct/layer.sql
Normal file
6
layers/kct/layer.sql
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
CREATE OR REPLACE FUNCTION layer_kct(bbox geometry, zoom_level int)
|
||||||
|
RETURNS TABLE(geometry geometry, name text, waycolor text) AS $$
|
||||||
|
SELECT geometry, NULLIF(name, '') AS name, SPLIT_PART(osmc_symbol, ':', 1) as waycolor
|
||||||
|
FROM osm_kct_relation
|
||||||
|
WHERE geometry && bbox;
|
||||||
|
$$ LANGUAGE SQL IMMUTABLE;
|
22
layers/kct/mapping.yaml
Normal file
22
layers/kct/mapping.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
tables:
|
||||||
|
# etldoc: imposm3 -> osm_kct_relation
|
||||||
|
kct_relation:
|
||||||
|
columns:
|
||||||
|
- name: geometry
|
||||||
|
type: geometry
|
||||||
|
- key: name
|
||||||
|
name: name
|
||||||
|
type: string
|
||||||
|
- key: osmc:symbol
|
||||||
|
name: osmc_symbol
|
||||||
|
type: string
|
||||||
|
mapping:
|
||||||
|
kct_blue:
|
||||||
|
- major
|
||||||
|
kct_green:
|
||||||
|
- major
|
||||||
|
kct_red:
|
||||||
|
- major
|
||||||
|
kct_yellow:
|
||||||
|
- major
|
||||||
|
type: relation_member
|
97
vfosnarmaptiles.yaml
Normal file
97
vfosnarmaptiles.yaml
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
tileset:
|
||||||
|
layers:
|
||||||
|
- layers/kct/kct.yaml
|
||||||
|
- layers/exploration/exploration.yaml
|
||||||
|
name: vfosnarMapTiles
|
||||||
|
version: 1.0.0
|
||||||
|
id: vfosnarmaptiles
|
||||||
|
description: ""
|
||||||
|
attribution: '<a href="https://www.openmaptiles.org/" target="_blank">© OpenMapTiles</a> <a href="https://www.openstreetmap.org/copyright" target="_blank">© OpenStreetMap contributors</a>'
|
||||||
|
center: [0, 0, 1]
|
||||||
|
bounds: [-180.0, -85.0511, 180.0, 85.0511]
|
||||||
|
maxzoom: 14
|
||||||
|
minzoom: 0
|
||||||
|
pixel_scale: 256
|
||||||
|
languages:
|
||||||
|
- am # Amharic
|
||||||
|
- ar # Arabic
|
||||||
|
- az # Azerbaijani, Latin
|
||||||
|
- be # Belorussian
|
||||||
|
- bg # Bulgarian
|
||||||
|
- bn # Bengali
|
||||||
|
- br # Breton, Latin
|
||||||
|
- bs # Bosnian, Latin
|
||||||
|
- ca # Catalan, Latin
|
||||||
|
- co # Corsican, Latin
|
||||||
|
- cs # Czech, Latin
|
||||||
|
- cy # Welsh, Latin
|
||||||
|
- da # Danish, Latin
|
||||||
|
- de # German, Latin
|
||||||
|
- el # Greek
|
||||||
|
- en # English, Latin
|
||||||
|
- eo # Esperanto, Latin
|
||||||
|
- es # Spanish, Latin
|
||||||
|
- et # Estonian, Latin
|
||||||
|
- eu # Basque, Latin
|
||||||
|
- fa # Persian
|
||||||
|
- fi # Finnish, Latin
|
||||||
|
- fr # French, Latin
|
||||||
|
- fy # Western Frisian, Latin
|
||||||
|
- ga # Irish, Latin
|
||||||
|
- gd # Scottish Gaelic, Latin
|
||||||
|
- he # Hebrew
|
||||||
|
- hi # Hindi
|
||||||
|
- hr # Croatian, Latin
|
||||||
|
- hu # Hungarian, Latin
|
||||||
|
- hy # Armenian
|
||||||
|
- id # Indonesian, Latin
|
||||||
|
- is # Icelandic, Latin
|
||||||
|
- it # Italian, Latin
|
||||||
|
- ja # Japanese
|
||||||
|
- ja_kana # Japanese Kana form
|
||||||
|
- ja_rm # romanization of Japanese, Latin
|
||||||
|
- ja-Latn # romanisation of Japanese, Latin since 2018
|
||||||
|
- ja-Hira # Japanese Hiragana form
|
||||||
|
- ka # Georgian
|
||||||
|
- kk # Kazakh
|
||||||
|
- kn # Kannada
|
||||||
|
- ko # Korean
|
||||||
|
- ko-Latn # romanization of Korean, Latin
|
||||||
|
- ku # Kurdish, Latin
|
||||||
|
- la # Latin, Latin
|
||||||
|
- lb # Luxembourgish, Latin
|
||||||
|
- lt # Lithuanian, Latin
|
||||||
|
- lv # Latvian, Latin
|
||||||
|
- mk # Macedonian
|
||||||
|
- mt # Maltese, Latin
|
||||||
|
- ml # Malayalam
|
||||||
|
- nl # Dutch, Latin
|
||||||
|
- "no" # Norwegian, Latin
|
||||||
|
- oc # Occitan (post 1500), Latin
|
||||||
|
- pa # Punjabi
|
||||||
|
- pnb # Western Punjabi
|
||||||
|
- pl # Polish, Latin
|
||||||
|
- pt # Portuguese, Latin
|
||||||
|
- rm # Romansh, Latin
|
||||||
|
- ro # Romania, Latin
|
||||||
|
- ru # Russian
|
||||||
|
- sk # Slovak, Latin
|
||||||
|
- sl # Slovene, Latin
|
||||||
|
- sq # Albanian, Latin
|
||||||
|
- sr # Serbian, Cyrillic
|
||||||
|
- sr-Latn # Serbian, Latin
|
||||||
|
- sv # Swedish, Latin
|
||||||
|
- ta # Tamil
|
||||||
|
- te # Telugu
|
||||||
|
- th # Thai
|
||||||
|
- tr # Turkish, Latin
|
||||||
|
- uk # Ukrainian
|
||||||
|
- ur # Urdu
|
||||||
|
- vi # Vietnamese, Latin
|
||||||
|
- zh # Chinese
|
||||||
|
- zh-Hant # Traditional Chinese
|
||||||
|
- zh-Hans # Simplified Chinese
|
||||||
|
defaults:
|
||||||
|
srs: +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over
|
||||||
|
datasource:
|
||||||
|
srid: 900913
|
Loading…
Reference in a new issue