Skip to main content

Lightweight Python client to interact with GeoServer Cloud REST API, GeoServer ACL and OGC services

Project description

python-geoservercloud

Installation

From PyPI:

pip install geoservercloud

From git repository:

poetry install

Quick start

from geoservercloud import GeoServerCloud
geoserver = GeoServerCloud(
    url="http://localhost:9090/geoserver/cloud/",
    user="admin",
    password="geoserver",
)
geoserver.create_workspace("newworkspace")

About

Lightweight Python client to interact with GeoServer Cloud REST API, GeoServer ACL and OGC services. Intended use cases are listed below.

Programmatic setup of a GeoServer catalog

For example, creating a workspace, connecting to a PostGIS datastore and publishing a PG layer:

geoserver.create_workspace("example")
geoserver.create_pg_datastore(
    workspace="example",
    datastore="example_store",
    pg_host="localhost",
    pg_port=5432,
    pg_db="database",
    pg_user="user",
    pg_password="password"
)
geoserver.create_feature_type(
    layer="layer_example"
    workspace="example",
    datastore="example_store",
    title={
        "en":"Layer title",
        "fr": "Titre de la couche",
        "default": "Default title",
    },
)

Testing

Automatic tests of GeoServer functionalities with pytest, for example before upgrading. The example below tests the fallback mechanism for internationalized layer titles in the GetCapabilities document.

@pytest.mark.parametrize(
    "language,expected_title",
    [
        (
            "en",
            "Layer title",
        ),
        (
            "fr",
            "Titre de la couche",
        ),
        (
            "de,en",
            "Layer title",
        ),
        (
            None,
            "Default title",
        ),
    ],
)
def test_i18n_layer_title(geoserver, language, expected_title):
    capabilities = geoserver.get_wms_layers(
        workspace="example",
        accept_languages=language,
    )
    layer = capabilities.get("Layer")
    assert layer.get("Title") == expected_title

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

geoservercloud-0.3.1.dev5.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

geoservercloud-0.3.1.dev5-py3-none-any.whl (27.9 kB view details)

Uploaded Python 3

File details

Details for the file geoservercloud-0.3.1.dev5.tar.gz.

File metadata

  • Download URL: geoservercloud-0.3.1.dev5.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.7

File hashes

Hashes for geoservercloud-0.3.1.dev5.tar.gz
Algorithm Hash digest
SHA256 6852d4878c3a687171d66bcf8b798649056abaf38abcc85baea45fe895651087
MD5 dcb1662ada07c9a34851f37f1b7fd406
BLAKE2b-256 ad3e14b81d9c2e3efee56026e3f8b9af68fce722d4e971e92e295485809c23a7

See more details on using hashes here.

File details

Details for the file geoservercloud-0.3.1.dev5-py3-none-any.whl.

File metadata

File hashes

Hashes for geoservercloud-0.3.1.dev5-py3-none-any.whl
Algorithm Hash digest
SHA256 430110a4fc30ec1fea428f7b652464b591936642d7383407b8a7961efddf462a
MD5 22a6d9e7071f8e33309d47eb0358d95c
BLAKE2b-256 ef1e3f8f7495b490fdd96775f5e354a2c10005c4c19a51489deccde76a5839df

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page