skip to navigation
skip to content

Not Logged In

gsconfig 0.6.1

GeoServer REST Configuration

Latest Version: 0.6.9
=========== is a python library for manipulating a GeoServer instance via the GeoServer RESTConfig API.


For users: ``pip install gsconfig``

For developers: ``git clone git:// && cd && python develop``
(`virtualenv <>`_ to taste.)

Getting Help
There is a brief manual at .
If you have questions, please ask them on the GeoServer Users mailing list: .
Please use the Github project at for any bug reports (and pull requests are welcome, but please include tests where possible.)

Sample Layer Creation Code

.. code-block::

    from geoserver.catalog import Catalog
    cat = Catalog("http://localhost:8080/geoserver/")
    topp ="topp")
    shapefile_plus_sidecars = shapefile_and_friends("states")
    # shapefile_and_friends should look on the filesystem to find a shapefile
    # and related files based on the base path passed in
    # shapefile_plus_sidecars == {
    #    'shp': 'states.shp',
    #    'shx': 'states.shx',
    #    'prj': 'states.prj',
    #    'dbf': 'states.dbf'
    # }

    # 'data' is required (there may be a 'schema' alternative later, for creating empty featuretypes)
    # 'workspace' is optional (GeoServer's default workspace is used by... default)
    # 'name' is required
    ft =, workspace=topp, data=shapefile_plus_sidecars)

Running Tests

Since the entire purpose of this module is to interact with GeoServer, the test suite is mostly composed of `integration tests <>`_.
These tests necessarily rely on a running copy of GeoServer, and expect that this GeoServer instance will be using the default data directory that is included with GeoServer.
This data is also included in the GeoServer source repository as ``/data/release/``.
In addition, it is expected that there will be a postgres database available at ``postgres:postgres@localhost:5432/db``.
You can test connecting to this database with the ``psql`` command line client by running ``$ psql -d db -Upostgres -h localhost -p 5432`` (you will be prompted interactively for the password.)

Here are the commands that I use to reset before running the gsconfig tests::

   $ cd ~/geoserver/src/web/app/
   $ PGUSER=postgres dropdb db
   $ PGUSER=postgres createdb db -T template_postgis
   $ git clean -dxff -- ../../../data/release/
   $ git checkout -f
   $ MAVEN_OPTS="-XX:PermSize=128M -Xmx1024M" \
   GEOSERVER_DATA_DIR=../../../data/release \
   mvn jetty:run

At this point, GeoServer will be running foregrounded, but it will take a few seconds to actually begin listening for http requests.
You can stop it with ``CTRL-C`` (but don't do that until you've run the tests!)
You can run the tests with the following command::

  $ python test
File Type Py Version Uploaded on Size
gsconfig-0.6.1.tar.gz (md5) Source 2012-09-05 13KB
  • Downloads (All Versions):
  • 58 downloads in the last day
  • 684 downloads in the last week
  • 2395 downloads in the last month