17.11. Layer ViewsΒΆ

A common use case for the Kafka data store is to expose a single layer with different default filters and relational transforms to different users. GeoMesa provides a way to do this through configuring views on top of the original layer.

To enabled layer views, use the kafka.layer.views data store parameter when creating a store:

import org.geotools.data.DataStore;
import org.geotools.data.DataStoreFinder;

String views =
  "{" +
  "  type1 = [" +
  "    { type-name = \"transformView\", transform = [ \"dtg\", \"geom\", \"name\" ] }," +
  "    { type-name = \"filterView\", filter = \"bbox(geom,0,0,10,10)\" }" +
  "  ]," +
  "  type2 = [" +
  "    { type-name = \"filterTransformView\", filter = \"bbox(geom,0,0,10,10)\", transform = [ \"dtg\", \"geom\" ] }" +
  "  ]" +
  "}";
Map<String, Serializable> parameters = new HashMap<>();
parameters.put("kafka.zookeepers", "localhost:2181");
parameters.put("kafka.brokers", "localhost:9092");
parameters.put("kafka.layer.views", views);
DataStore dataStore = DataStoreFinder.getDataStore(parameters);

The views parameter accepts a TypeSafe config string containing the view definitions. In the above example, assuming there are existing schemas named type1 and type2, three additional schemas will be exposed with the names transformView, filterView and filterTransformView. The transform views have a subset of the attributes from the original schema, while the filter views have a subset of the features in the original schema. Each view must define either a filter, a transform or both.