Skip to content

Latest commit

 

History

History
51 lines (42 loc) · 4.49 KB

README.md

File metadata and controls

51 lines (42 loc) · 4.49 KB

mongodb-geoserver

A MongoDB plugin for Geoserver.

Download Geoserver 2.8.3 (Platform Independent Binary)

To setup a dev environment:

  1. Download deployment from here
  2. Unzip the deployment
  3. Move the groovy jar, the mongo java driver jar and the mongodb-geoserver jar into geoserver/WEB-INF/lib
  4. Restart geoserver.

Add a store and layers for development

  1. Create a mapping file that includes a mapping for each mongo collection that will be published.
  2. In geoserver, click "Workspaces", then click "Add new workspace"
  3. Set the name to "DB" and the Namespace URI to "http://spida/db" and check Default Workspace
  4. In geoserver, click "Stores", then click "Add new Store", then click "Mongo DB"
  5. Select the DB workspace, name it SPIDADB, set MongoDB connection parameters, and the path to the mapping file.
  6. If automatically brought to the layers page to publish layers, skip the next step
  7. In geoserver, click "Layers", then click "Add new resource", then select "DB:SPIDADB"
  8. Publish each layer. Set Declared SRS to "EPSG:4326" and bounding box values all to 1

You can see all types and properties at this geoserver url. And here is a WFS Reference.

NOTE: When min builds this is all done automatically by copying files from min/scripts/docker/tomcat/geoserver

Point projectmanager at geoserver

  1. Uncomment url so that asset service bean gets created.
  2. Start projectmanager
  3. Edit a permission group and add the spida db asset service.

Mapping file

The mapping file will map a feature collection to a mongo collection. If there is multiple objects nested in a collection each nested object can be published as a feature. Here is an example mapping.json file. There is also a location.json and design.json that the mapping file and tests use.

Top level fields in the mapping.json file:

  • typeName: (Required) The typeName for the feature that geoserver will use
  • collection: (Required) The MongoDB collection that the feature is located in.
  • idAsAttribute: (Required) Whether or not to include the id of the object as an attribute for the features.
  • geometry: (Not Required) The geometry for the collection, must include the name, crs and path.
  • displayGeometry: (Not Required) Whether or not to add the geometry to the feature.
  • attributes: (Not Required) Must add the name for the attribute and the path to the value, can also add a class(Double, Long or Boolean)
  • subCollections: (Not Required)
    • subCollectionPath: (Required) path to the subcollection.
    • includeInDefaultQuery: (Required) If true the query for objects will include a criteria that the length of the array is greater than 0.
    • attributes: (Not Required) Similar to attributes for top level objects but more options instead of just the path value.