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.dev16.tar.gz (21.5 kB view details)

Uploaded Source

Built Distribution

geoservercloud-0.3.1.dev16-py3-none-any.whl (29.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for geoservercloud-0.3.1.dev16.tar.gz
Algorithm Hash digest
SHA256 50a6654f423b8dab7ed48bad619ce9c0fd281457957ca23f87868d763f9c524c
MD5 be42eaf125559eb113bf417a88f79b80
BLAKE2b-256 a32888bb5bf1c8bd56ad61fcc210a1907b93e31184407c80df3d79ca60803c05

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for geoservercloud-0.3.1.dev16-py3-none-any.whl
Algorithm Hash digest
SHA256 fe7498bc9df004eb06734fc625f7c834b1fad3137953f8df91a3e7e395974cc7
MD5 87999573d7340f8665c95f6929ec8e52
BLAKE2b-256 029d5ea341e864feb086563a2125b0c7c6ea41edb2b17e86f5c1160d0a7375e9

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