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

Uploaded Source

Built Distribution

geoservercloud-0.3.1.dev2-py3-none-any.whl (23.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for geoservercloud-0.3.1.dev2.tar.gz
Algorithm Hash digest
SHA256 49427ed4350af2e84dbec9039dcee65943c46eef030e82d41bb9fa4d89d1ddaf
MD5 1332097583edcc98bf90d400674dd313
BLAKE2b-256 24618c587f59d76084e140bf11b8c7d5da746379dfb3cbc3bf379f903cfe8f8f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for geoservercloud-0.3.1.dev2-py3-none-any.whl
Algorithm Hash digest
SHA256 aead2b971b26f9c004d67b23963ea5d7e5f858305cb2eb3d277e30b5ddd19860
MD5 20798fce0145cc29b58595c9efc571e5
BLAKE2b-256 91f3d49b08b0cc487f2307c4e185579247b03ff0dc5062a4a2e34d9fab03f9ee

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