Skip to content

rcaner/mongodb-geoserver

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

82 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.

About

A MongoDB plugin for GeoServer

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Groovy 100.0%