Skip to main content

Django speaking WFS 2.0 (exposing GeoDjango model fields)

Project description

Travis PyPI MPL License Coverage

django-gisserver

Django speaking WFS 2.0 to expose geo data.

Features

  • WFS 2.0 simple implementation.
  • GML 3.2 output.
  • Standard and spatial filtering (FES 2.0)
  • GeoJSON and CSV export formats.
  • Extensible view/operations.
  • Uses GeoDjango queries for filtering.
  • Streaming responses for large datasets.

Usage

Create a model that exposes a GeoDjango field:

from django.contrib.gis.db.models import PointField
from django.db import models


class Restaurant(models.Model):
    name = models.CharField(max_length=200)
    location = PointField(null=True)

    def __str__(self):
        return self.name

Write a view that exposes this model as a WFS feature:

from gisserver.features import FeatureType, ServiceDescription
from gisserver.geometries import CRS, WGS84
from gisserver.views import WFSView
from .models import Restaurant

RD_NEW = CRS.from_srid(28992)


class PlacesWFSView(WFSView):
    """An simple view that uses the WFSView against our test model."""

    xml_namespace = "http://example.org/gisserver"

    # The service metadata
    service_description = ServiceDescription(
        title="Places",
        abstract="Unittesting",
        keywords=["django-gisserver"],
        provider_name="Django",
        provider_site="https://www.example.com/",
        contact_person="django-gisserver",
    )

    # Each Django model is listed here as a feature.
    feature_types = [
        FeatureType(
            Restaurant.objects.all(),
            fields="__all__",
            other_crs=[RD_NEW]
        ),
    ]

Use that view in the URLConf:

from django.urls import path
from . import views

urlpatterns = [
    path("/wfs/places/", views.PlacesWFSView.as_view()),
]

You can now use http://localhost:8000/wfs/places/ in your GIS application. It will perform requests such as:

By adding &OUTPUTFORMAT=geojson or &OUTPUTFORMAT=csv to the GetFeature request, the GeoJSON and CSV outputs are returned. The CSV output has an unlimited page size, as it's quite performant.

Configuring fields

By default, only the geometry field is exposed as WFS attribute. Use the FeatureType(..., fields=[...]) parameter to define which fields should be exposed.

It's possible to expose foreign key relations too as complex fields:

from gisserver.features import FeatureType, field


class CustomWFSView(WFSView):
    ...

    feature_types = [
        FeatureType(
            Restaurant.objects.all(),
            fields=[
                "id",
                "name",
                "location",
                field("owner", fields=["id", "name", "phonenumber"])
                "created"
            ],
        ),
    ]

Customization hooks

There are a few places that allow to customize the WFS logic:

  • Overriding methods from WFSView, such as get_feature_types() or dispatch() for authorization.
  • Subclassing the FeatureType class, to override it's get_queryset() method.
  • Subclassing the FeatureField class for the FeatureType(fields=...) parameter.
  • Registering new FES functions to gisserver.parsers.fes_function_registry.
  • Registering new stored procedures to gisserver.queries.stored_query_registry.

Debugging questions

  • The error "Operation on mixed SRID geometries" often indicates the table SRID differs from the GeometryField(srid=..) configuration in Django.

Standards compliance

Nearly all operations for the WFS simple conformance class are implemented. You should be able to view the WFS server QGis. The unit tests validate the output against WFS 2.0 XSD schema.

Some remaining parts for the "WFS simple" conformance level are not implemented yet:

  • KVP filters: propertyName, aliases, namespaces.
  • Remote resolving: resolve, resolveDepth, resolveTimeout.
  • Some GetCapabilities features: acceptFormats and sections.
  • Temporal filtering (high on todo)

Low-prio items:

Anything outside WFS simple could be implemented, but is very low on the todo-list:

  • The methods for the WFS transactional, locking and inheritance conformance classes.
  • HTTP POST requests.
  • SOAP requests.
  • Other protocols (WMS, WMTS, WCS)
  • Other output formats (shapefile, KML, GML 3.1) - but easy to add.

Development

When you follow the source of the WFSView, WFSMethod and Parameter classes, you'll find that it's written with extensibility in mind. Extra parameters and operations can easily be added there. You could even do that within your own projects and implementations.

A lot of the internal classes and object names are direct copies from the WFS spec. By following these type definitions, a lot of the logic and code structure follows naturally.

The Makefile gives you all you need to start working on the project. Typing make gives an overview of all possible shortcut commands.

The WFS specification and examples be found at:

Some deeplinks:

Other links:

Why this code is shared

The "datapunt" team of the Municipality of Amsterdam develops software for the municipality. Much of this software is then published as Open Source so that other municipalities, organizations and citizens can use the software as a basis and inspiration to develop similar software themselves. The Municipality of Amsterdam considers it important that software developed with public money is also publicly available.

This package is initially developed by the City of Amsterdam, but the tools and concepts created in this project can be used in any city.

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

django-gisserver-0.8.2.tar.gz (70.3 kB view details)

Uploaded Source

Built Distribution

django_gisserver-0.8.2-py2.py3-none-any.whl (86.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-gisserver-0.8.2.tar.gz.

File metadata

  • Download URL: django-gisserver-0.8.2.tar.gz
  • Upload date:
  • Size: 70.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.10.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/2.7.17

File hashes

Hashes for django-gisserver-0.8.2.tar.gz
Algorithm Hash digest
SHA256 8e7f3b3e31fc94390e20f7fae337d6331a6891a5cd3f06fed2a41718c15784ef
MD5 026ca8ae1721981bed09b5938a2cf172
BLAKE2b-256 7d91b427a89107920695f11faa0221418a2fce48fb4c5c1aeda8a9cccafaf439

See more details on using hashes here.

File details

Details for the file django_gisserver-0.8.2-py2.py3-none-any.whl.

File metadata

  • Download URL: django_gisserver-0.8.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 86.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.10.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/2.7.17

File hashes

Hashes for django_gisserver-0.8.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 cdc187619c244690aebb9902eeeda4d44161c62c30f96665b09fe025ff5dfc92
MD5 e2471bd6f7019859c634d7749025dc75
BLAKE2b-256 24464fd1b98fa2bd1c3608d3cbd4cf7aab80e2628fe64af3d24ae71cd4554662

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